Shell: Check line format file and loop over file lines

Multi tool use
Multi tool use

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
1
down vote

favorite












I need to check 2 assetions:



  1. The file content format

  2. Iterate over that content:

So, the content file must be:



key1=value
key2=value2
...


So, each line must have the format key=value. Spaces are not allowed before or after the =. This file content has to be an env format file.



By other hand, I need to split out each line into a key and a value inside a loop.



Any ideas?







share|improve this question

















  • 1




    What are the restrictions on the key and value? Single words? Are quoted strings ok? Are multi-line value ok? Are values containing = ok?
    – Kusalananda
    Jun 26 at 14:26










  • Only has to match <word>=<word>
    – Jordi
    Jun 26 at 14:42










  • Right, but can a "word" be preference=apple-juice for a valid line reading drink=preference=apple-juice? Are spaces allowed before and/or after the =?
    – DopeGhoti
    Jun 26 at 15:26











  • No. This file content has to be an env format file.
    – Jordi
    Jun 26 at 15:27










  • Do you mean that key1=value with spaces should be rejected, or that it should be parsed as key=key1 and value=value with spaces?
    – Gilles
    Jun 27 at 15:28














up vote
1
down vote

favorite












I need to check 2 assetions:



  1. The file content format

  2. Iterate over that content:

So, the content file must be:



key1=value
key2=value2
...


So, each line must have the format key=value. Spaces are not allowed before or after the =. This file content has to be an env format file.



By other hand, I need to split out each line into a key and a value inside a loop.



Any ideas?







share|improve this question

















  • 1




    What are the restrictions on the key and value? Single words? Are quoted strings ok? Are multi-line value ok? Are values containing = ok?
    – Kusalananda
    Jun 26 at 14:26










  • Only has to match <word>=<word>
    – Jordi
    Jun 26 at 14:42










  • Right, but can a "word" be preference=apple-juice for a valid line reading drink=preference=apple-juice? Are spaces allowed before and/or after the =?
    – DopeGhoti
    Jun 26 at 15:26











  • No. This file content has to be an env format file.
    – Jordi
    Jun 26 at 15:27










  • Do you mean that key1=value with spaces should be rejected, or that it should be parsed as key=key1 and value=value with spaces?
    – Gilles
    Jun 27 at 15:28












up vote
1
down vote

favorite









up vote
1
down vote

favorite











I need to check 2 assetions:



  1. The file content format

  2. Iterate over that content:

So, the content file must be:



key1=value
key2=value2
...


So, each line must have the format key=value. Spaces are not allowed before or after the =. This file content has to be an env format file.



By other hand, I need to split out each line into a key and a value inside a loop.



Any ideas?







share|improve this question













I need to check 2 assetions:



  1. The file content format

  2. Iterate over that content:

So, the content file must be:



key1=value
key2=value2
...


So, each line must have the format key=value. Spaces are not allowed before or after the =. This file content has to be an env format file.



By other hand, I need to split out each line into a key and a value inside a loop.



Any ideas?









share|improve this question












share|improve this question




share|improve this question








edited Jun 27 at 15:28









Gilles

502k1179901515




502k1179901515









asked Jun 26 at 14:15









Jordi

1424




1424







  • 1




    What are the restrictions on the key and value? Single words? Are quoted strings ok? Are multi-line value ok? Are values containing = ok?
    – Kusalananda
    Jun 26 at 14:26










  • Only has to match <word>=<word>
    – Jordi
    Jun 26 at 14:42










  • Right, but can a "word" be preference=apple-juice for a valid line reading drink=preference=apple-juice? Are spaces allowed before and/or after the =?
    – DopeGhoti
    Jun 26 at 15:26











  • No. This file content has to be an env format file.
    – Jordi
    Jun 26 at 15:27










  • Do you mean that key1=value with spaces should be rejected, or that it should be parsed as key=key1 and value=value with spaces?
    – Gilles
    Jun 27 at 15:28












  • 1




    What are the restrictions on the key and value? Single words? Are quoted strings ok? Are multi-line value ok? Are values containing = ok?
    – Kusalananda
    Jun 26 at 14:26










  • Only has to match <word>=<word>
    – Jordi
    Jun 26 at 14:42










  • Right, but can a "word" be preference=apple-juice for a valid line reading drink=preference=apple-juice? Are spaces allowed before and/or after the =?
    – DopeGhoti
    Jun 26 at 15:26











  • No. This file content has to be an env format file.
    – Jordi
    Jun 26 at 15:27










  • Do you mean that key1=value with spaces should be rejected, or that it should be parsed as key=key1 and value=value with spaces?
    – Gilles
    Jun 27 at 15:28







1




1




What are the restrictions on the key and value? Single words? Are quoted strings ok? Are multi-line value ok? Are values containing = ok?
– Kusalananda
Jun 26 at 14:26




What are the restrictions on the key and value? Single words? Are quoted strings ok? Are multi-line value ok? Are values containing = ok?
– Kusalananda
Jun 26 at 14:26












Only has to match <word>=<word>
– Jordi
Jun 26 at 14:42




Only has to match <word>=<word>
– Jordi
Jun 26 at 14:42












Right, but can a "word" be preference=apple-juice for a valid line reading drink=preference=apple-juice? Are spaces allowed before and/or after the =?
– DopeGhoti
Jun 26 at 15:26





Right, but can a "word" be preference=apple-juice for a valid line reading drink=preference=apple-juice? Are spaces allowed before and/or after the =?
– DopeGhoti
Jun 26 at 15:26













No. This file content has to be an env format file.
– Jordi
Jun 26 at 15:27




No. This file content has to be an env format file.
– Jordi
Jun 26 at 15:27












Do you mean that key1=value with spaces should be rejected, or that it should be parsed as key=key1 and value=value with spaces?
– Gilles
Jun 27 at 15:28




Do you mean that key1=value with spaces should be rejected, or that it should be parsed as key=key1 and value=value with spaces?
– Gilles
Jun 27 at 15:28










2 Answers
2






active

oldest

votes

















up vote
3
down vote



accepted










With bash:



n=0
while IFS="=" read -r key value; do
((n++))
if [[ -z $key ]]; then echo "missing key on line $n"; continue; fi
if [[ -z $value ]]; then echo "empty value on line $n"; continue; fi
echo "key:>$key<; value:>$value<"
done <<END
key1=value1
key2=value2
key3=
=value3
foo

key4=value4=value5=value6
END


outputs



key:>key1<; value:>value1<
key:>key2<; value:>value2<
empty value on line 3
missing key on line 4
empty value on line 5
missing key on line 6
key:>key4<; value:>value4=value5=value6<





share|improve this answer




























    up vote
    2
    down vote













    Given this file as input:



    key1=value1
    key2=value2
    key3=
    =value3
    key4=value4


    We can use = as a field separator for awk:



    $ awk -F= '!($1 && $2 && NF==2) print "File failed validation on line " NR; exit 1 print $1, $2 ' input
    key1 value1
    key2 value2
    File failed validation on line 3


    To throw validation error messages to standard error, the print statement can be modified, and to continue processing after an error is seen, change the exit statement to a next statement:



    $ awk -F= '!($1 && $2 && NF==2) "cat 1>&2"; next print $1, $2 ' input
    [stdout] key1 value1
    [stdout] key2 value2
    [stdout] key4 value4
    [stderr] File failed validation on line 3
    [stderr] File failed validation on line 4


    Validation is done in three steps; if any of these criteria are not met the error is thrown and, in the first example, execution is aborted with an error-state exit code:




    • $1 - Ensure that there is (in the parlance of the input specification) a "key"


    • $2 - Ensure that there is (in the parlance of the input specification) a "value"


    • NF==2 - Ensure that there are only two fields; the aforementioned "key" and "value"





    share|improve this answer























      Your Answer







      StackExchange.ready(function()
      var channelOptions =
      tags: "".split(" "),
      id: "106"
      ;
      initTagRenderer("".split(" "), "".split(" "), channelOptions);

      StackExchange.using("externalEditor", function()
      // Have to fire editor after snippets, if snippets enabled
      if (StackExchange.settings.snippets.snippetsEnabled)
      StackExchange.using("snippets", function()
      createEditor();
      );

      else
      createEditor();

      );

      function createEditor()
      StackExchange.prepareEditor(
      heartbeatType: 'answer',
      convertImagesToLinks: false,
      noModals: false,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: null,
      bindNavPrevention: true,
      postfix: "",
      onDemand: true,
      discardSelector: ".discard-answer"
      ,immediatelyShowMarkdownHelp:true
      );



      );








       

      draft saved


      draft discarded


















      StackExchange.ready(
      function ()
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f452028%2fshell-check-line-format-file-and-loop-over-file-lines%23new-answer', 'question_page');

      );

      Post as a guest






























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes








      up vote
      3
      down vote



      accepted










      With bash:



      n=0
      while IFS="=" read -r key value; do
      ((n++))
      if [[ -z $key ]]; then echo "missing key on line $n"; continue; fi
      if [[ -z $value ]]; then echo "empty value on line $n"; continue; fi
      echo "key:>$key<; value:>$value<"
      done <<END
      key1=value1
      key2=value2
      key3=
      =value3
      foo

      key4=value4=value5=value6
      END


      outputs



      key:>key1<; value:>value1<
      key:>key2<; value:>value2<
      empty value on line 3
      missing key on line 4
      empty value on line 5
      missing key on line 6
      key:>key4<; value:>value4=value5=value6<





      share|improve this answer

























        up vote
        3
        down vote



        accepted










        With bash:



        n=0
        while IFS="=" read -r key value; do
        ((n++))
        if [[ -z $key ]]; then echo "missing key on line $n"; continue; fi
        if [[ -z $value ]]; then echo "empty value on line $n"; continue; fi
        echo "key:>$key<; value:>$value<"
        done <<END
        key1=value1
        key2=value2
        key3=
        =value3
        foo

        key4=value4=value5=value6
        END


        outputs



        key:>key1<; value:>value1<
        key:>key2<; value:>value2<
        empty value on line 3
        missing key on line 4
        empty value on line 5
        missing key on line 6
        key:>key4<; value:>value4=value5=value6<





        share|improve this answer























          up vote
          3
          down vote



          accepted







          up vote
          3
          down vote



          accepted






          With bash:



          n=0
          while IFS="=" read -r key value; do
          ((n++))
          if [[ -z $key ]]; then echo "missing key on line $n"; continue; fi
          if [[ -z $value ]]; then echo "empty value on line $n"; continue; fi
          echo "key:>$key<; value:>$value<"
          done <<END
          key1=value1
          key2=value2
          key3=
          =value3
          foo

          key4=value4=value5=value6
          END


          outputs



          key:>key1<; value:>value1<
          key:>key2<; value:>value2<
          empty value on line 3
          missing key on line 4
          empty value on line 5
          missing key on line 6
          key:>key4<; value:>value4=value5=value6<





          share|improve this answer













          With bash:



          n=0
          while IFS="=" read -r key value; do
          ((n++))
          if [[ -z $key ]]; then echo "missing key on line $n"; continue; fi
          if [[ -z $value ]]; then echo "empty value on line $n"; continue; fi
          echo "key:>$key<; value:>$value<"
          done <<END
          key1=value1
          key2=value2
          key3=
          =value3
          foo

          key4=value4=value5=value6
          END


          outputs



          key:>key1<; value:>value1<
          key:>key2<; value:>value2<
          empty value on line 3
          missing key on line 4
          empty value on line 5
          missing key on line 6
          key:>key4<; value:>value4=value5=value6<






          share|improve this answer













          share|improve this answer



          share|improve this answer











          answered Jun 26 at 16:55









          glenn jackman

          45.6k264100




          45.6k264100






















              up vote
              2
              down vote













              Given this file as input:



              key1=value1
              key2=value2
              key3=
              =value3
              key4=value4


              We can use = as a field separator for awk:



              $ awk -F= '!($1 && $2 && NF==2) print "File failed validation on line " NR; exit 1 print $1, $2 ' input
              key1 value1
              key2 value2
              File failed validation on line 3


              To throw validation error messages to standard error, the print statement can be modified, and to continue processing after an error is seen, change the exit statement to a next statement:



              $ awk -F= '!($1 && $2 && NF==2) "cat 1>&2"; next print $1, $2 ' input
              [stdout] key1 value1
              [stdout] key2 value2
              [stdout] key4 value4
              [stderr] File failed validation on line 3
              [stderr] File failed validation on line 4


              Validation is done in three steps; if any of these criteria are not met the error is thrown and, in the first example, execution is aborted with an error-state exit code:




              • $1 - Ensure that there is (in the parlance of the input specification) a "key"


              • $2 - Ensure that there is (in the parlance of the input specification) a "value"


              • NF==2 - Ensure that there are only two fields; the aforementioned "key" and "value"





              share|improve this answer



























                up vote
                2
                down vote













                Given this file as input:



                key1=value1
                key2=value2
                key3=
                =value3
                key4=value4


                We can use = as a field separator for awk:



                $ awk -F= '!($1 && $2 && NF==2) print "File failed validation on line " NR; exit 1 print $1, $2 ' input
                key1 value1
                key2 value2
                File failed validation on line 3


                To throw validation error messages to standard error, the print statement can be modified, and to continue processing after an error is seen, change the exit statement to a next statement:



                $ awk -F= '!($1 && $2 && NF==2) "cat 1>&2"; next print $1, $2 ' input
                [stdout] key1 value1
                [stdout] key2 value2
                [stdout] key4 value4
                [stderr] File failed validation on line 3
                [stderr] File failed validation on line 4


                Validation is done in three steps; if any of these criteria are not met the error is thrown and, in the first example, execution is aborted with an error-state exit code:




                • $1 - Ensure that there is (in the parlance of the input specification) a "key"


                • $2 - Ensure that there is (in the parlance of the input specification) a "value"


                • NF==2 - Ensure that there are only two fields; the aforementioned "key" and "value"





                share|improve this answer

























                  up vote
                  2
                  down vote










                  up vote
                  2
                  down vote









                  Given this file as input:



                  key1=value1
                  key2=value2
                  key3=
                  =value3
                  key4=value4


                  We can use = as a field separator for awk:



                  $ awk -F= '!($1 && $2 && NF==2) print "File failed validation on line " NR; exit 1 print $1, $2 ' input
                  key1 value1
                  key2 value2
                  File failed validation on line 3


                  To throw validation error messages to standard error, the print statement can be modified, and to continue processing after an error is seen, change the exit statement to a next statement:



                  $ awk -F= '!($1 && $2 && NF==2) "cat 1>&2"; next print $1, $2 ' input
                  [stdout] key1 value1
                  [stdout] key2 value2
                  [stdout] key4 value4
                  [stderr] File failed validation on line 3
                  [stderr] File failed validation on line 4


                  Validation is done in three steps; if any of these criteria are not met the error is thrown and, in the first example, execution is aborted with an error-state exit code:




                  • $1 - Ensure that there is (in the parlance of the input specification) a "key"


                  • $2 - Ensure that there is (in the parlance of the input specification) a "value"


                  • NF==2 - Ensure that there are only two fields; the aforementioned "key" and "value"





                  share|improve this answer















                  Given this file as input:



                  key1=value1
                  key2=value2
                  key3=
                  =value3
                  key4=value4


                  We can use = as a field separator for awk:



                  $ awk -F= '!($1 && $2 && NF==2) print "File failed validation on line " NR; exit 1 print $1, $2 ' input
                  key1 value1
                  key2 value2
                  File failed validation on line 3


                  To throw validation error messages to standard error, the print statement can be modified, and to continue processing after an error is seen, change the exit statement to a next statement:



                  $ awk -F= '!($1 && $2 && NF==2) "cat 1>&2"; next print $1, $2 ' input
                  [stdout] key1 value1
                  [stdout] key2 value2
                  [stdout] key4 value4
                  [stderr] File failed validation on line 3
                  [stderr] File failed validation on line 4


                  Validation is done in three steps; if any of these criteria are not met the error is thrown and, in the first example, execution is aborted with an error-state exit code:




                  • $1 - Ensure that there is (in the parlance of the input specification) a "key"


                  • $2 - Ensure that there is (in the parlance of the input specification) a "value"


                  • NF==2 - Ensure that there are only two fields; the aforementioned "key" and "value"






                  share|improve this answer















                  share|improve this answer



                  share|improve this answer








                  edited Jun 26 at 15:43


























                  answered Jun 26 at 15:37









                  DopeGhoti

                  39.7k54779




                  39.7k54779






















                       

                      draft saved


                      draft discarded


























                       


                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function ()
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f452028%2fshell-check-line-format-file-and-loop-over-file-lines%23new-answer', 'question_page');

                      );

                      Post as a guest













































































                      rgCxWfJLog1B7JCBMdKg4Ona7llF8fN8rv S2 tC
                      uUpxg 8WxtNLkddW,BbMTkp4wutIOXrORNZJxR Lr,hz6g,sVFbMZ jq 8uUT6iVYcp

                      Popular posts from this blog

                      How to check contact read email or not when send email to Individual?

                      How many registers does an x86_64 CPU actually have?

                      Displaying single band from multi-band raster using QGIS