Bash - Looping through Array in Nested [FOR, WHILE, IF] statements The 2019 Stack Overflow Developer Survey Results Are InWhy is using a shell loop to process text considered bad practice?How do I test if an item is in a bash array?How to name a file in the deepest level of a directory treeBash: Looping through a stringBASH: looping through lsBash script for looping through filesload bash comands from file one per line and execute them for each file in a directoryBASH attempting to leave nested statements/loops/functionsLooping through lines in several files (bash)Bash - Looping through nested for loop using arraysLooping through an array with for gives different resultsError in Bash Script Nested Conditional Statements

Can you compress metal and what would be the consequences?

Delete all lines which don't have n characters before delimiter

How to manage monthly salary

What does ひと匙 mean in this manga and has it been used colloquially?

What are the motivations for publishing new editions of an existing textbook, beyond new discoveries in a field?

Where to refill my bottle in India?

Why isn't airport relocation done gradually?

Geography at the pixel level

Is an up-to-date browser secure on an out-of-date OS?

What do hard-Brexiteers want with respect to the Irish border?

Why do UK politicians seemingly ignore opinion polls on Brexit?

Shouldn't "much" here be used instead of "more"?

Falsification in Math vs Science

Lightning Grid - Columns and Rows?

How to deal with fear of taking dependencies

How can I autofill dates in Excel excluding Sunday?

Aging parents with no investments

"as much details as you can remember"

Why didn't the Event Horizon Telescope team mention Sagittarius A*?

Is this app Icon Browser Safe/Legit?

Are spiders unable to hurt humans, especially very small spiders?

Can a flute soloist sit?

Why can Shazam fly?

Have you ever entered Singapore using a different passport or name?



Bash - Looping through Array in Nested [FOR, WHILE, IF] statements



The 2019 Stack Overflow Developer Survey Results Are InWhy is using a shell loop to process text considered bad practice?How do I test if an item is in a bash array?How to name a file in the deepest level of a directory treeBash: Looping through a stringBASH: looping through lsBash script for looping through filesload bash comands from file one per line and execute them for each file in a directoryBASH attempting to leave nested statements/loops/functionsLooping through lines in several files (bash)Bash - Looping through nested for loop using arraysLooping through an array with for gives different resultsError in Bash Script Nested Conditional Statements



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








3















I am trying to process a large file-set, appending specific lines into the "test_result.txt" file - I achieved it -not very elegantly- with the following code.



for i in *merged; do
while read -r lo; do
if [[ $lo == *"ID"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"Instance"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"NOT"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"AI"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"Sitting"* ]]; then
echo $lo >> test_result.txt

done < $i
done


However, I am trying to size-it-down using an array - which resulted in quite an unsuccessful attempt.



KEYWORDS=("ID" "Instance" "NOT" "AI" "Sitting" )
KEY_COUNT=0

for i in *merged; do
while read -r lo; do
if [[$lo == $KEYWORDS[@] ]]; then
echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
fi
done < $i
done









share|improve this question









New contributor




AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.















  • 3





    How large is the file set? This sounds like an XY problem that could be better accomplished by a straightforward grep command.

    – steeldriver
    17 hours ago






  • 2





    Small side note: Instead of KEY_COUNT="`expr $KEY_COUNT + 1`" you could also write ((KEY_COUNT++))

    – Freddy
    17 hours ago

















3















I am trying to process a large file-set, appending specific lines into the "test_result.txt" file - I achieved it -not very elegantly- with the following code.



for i in *merged; do
while read -r lo; do
if [[ $lo == *"ID"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"Instance"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"NOT"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"AI"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"Sitting"* ]]; then
echo $lo >> test_result.txt

done < $i
done


However, I am trying to size-it-down using an array - which resulted in quite an unsuccessful attempt.



KEYWORDS=("ID" "Instance" "NOT" "AI" "Sitting" )
KEY_COUNT=0

for i in *merged; do
while read -r lo; do
if [[$lo == $KEYWORDS[@] ]]; then
echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
fi
done < $i
done









share|improve this question









New contributor




AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.















  • 3





    How large is the file set? This sounds like an XY problem that could be better accomplished by a straightforward grep command.

    – steeldriver
    17 hours ago






  • 2





    Small side note: Instead of KEY_COUNT="`expr $KEY_COUNT + 1`" you could also write ((KEY_COUNT++))

    – Freddy
    17 hours ago













3












3








3








I am trying to process a large file-set, appending specific lines into the "test_result.txt" file - I achieved it -not very elegantly- with the following code.



for i in *merged; do
while read -r lo; do
if [[ $lo == *"ID"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"Instance"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"NOT"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"AI"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"Sitting"* ]]; then
echo $lo >> test_result.txt

done < $i
done


However, I am trying to size-it-down using an array - which resulted in quite an unsuccessful attempt.



KEYWORDS=("ID" "Instance" "NOT" "AI" "Sitting" )
KEY_COUNT=0

for i in *merged; do
while read -r lo; do
if [[$lo == $KEYWORDS[@] ]]; then
echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
fi
done < $i
done









share|improve this question









New contributor




AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.












I am trying to process a large file-set, appending specific lines into the "test_result.txt" file - I achieved it -not very elegantly- with the following code.



for i in *merged; do
while read -r lo; do
if [[ $lo == *"ID"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"Instance"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"NOT"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"AI"* ]]; then
echo $lo >> test_result.txt
fi
if [[ $lo == *"Sitting"* ]]; then
echo $lo >> test_result.txt

done < $i
done


However, I am trying to size-it-down using an array - which resulted in quite an unsuccessful attempt.



KEYWORDS=("ID" "Instance" "NOT" "AI" "Sitting" )
KEY_COUNT=0

for i in *merged; do
while read -r lo; do
if [[$lo == $KEYWORDS[@] ]]; then
echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
fi
done < $i
done






bash






share|improve this question









New contributor




AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question









New contributor




AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question








edited 5 hours ago









Rui F Ribeiro

42k1483142




42k1483142






New contributor




AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked 18 hours ago









AF.BJAF.BJ

164




164




New contributor




AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






AF.BJ is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







  • 3





    How large is the file set? This sounds like an XY problem that could be better accomplished by a straightforward grep command.

    – steeldriver
    17 hours ago






  • 2





    Small side note: Instead of KEY_COUNT="`expr $KEY_COUNT + 1`" you could also write ((KEY_COUNT++))

    – Freddy
    17 hours ago












  • 3





    How large is the file set? This sounds like an XY problem that could be better accomplished by a straightforward grep command.

    – steeldriver
    17 hours ago






  • 2





    Small side note: Instead of KEY_COUNT="`expr $KEY_COUNT + 1`" you could also write ((KEY_COUNT++))

    – Freddy
    17 hours ago







3




3





How large is the file set? This sounds like an XY problem that could be better accomplished by a straightforward grep command.

– steeldriver
17 hours ago





How large is the file set? This sounds like an XY problem that could be better accomplished by a straightforward grep command.

– steeldriver
17 hours ago




2




2





Small side note: Instead of KEY_COUNT="`expr $KEY_COUNT + 1`" you could also write ((KEY_COUNT++))

– Freddy
17 hours ago





Small side note: Instead of KEY_COUNT="`expr $KEY_COUNT + 1`" you could also write ((KEY_COUNT++))

– Freddy
17 hours ago










2 Answers
2






active

oldest

votes


















5














It looks like you want to get all the lines that contains at least one out of a set of words, from a set of files.



Assuming that you don't have many thousands of files, you could do that with a single grep command:



grep -wE '(ID|Instance|NOT|AI|Sitting)' ./*merged >outputfile


This would extract the lines matching any of the words listed in the pattern from the files whose names matches *merged.



The -w with grep ensures that the given strings are not matched as substrings (i.e. NOT will not be matched in NOTICE). The -E option enables the alternation with | in the pattern.



Add the -h option to the command if you don't want the names of the files containing matching lines in the output.



If you do have many thousands of files, the above command may fail due to expanding to a too long command line. In that case, you may want to do something like



for file in ./*merged; do
grep -wE '(ID|Instance|NOT|AI|Sitting)' "$file"
done >outputfile


which would run the grep command once on each file, or,



find . -maxdepth 1 -type f -name '*merged' 
-exec grep -wE '(ID|Instance|NOT|AI|Sitting)' + >outputfile


which would do as few invocations of grep as possible with as many files as possible at once.



Related:



  • Why is using a shell loop to process text considered bad practice?





share|improve this answer




















  • 1





    It is indeed a file-set of a few thousand. Originally, I built other processes into the loop but running grep separately - before the extra tweakings - it's a cleaner solution. Just needed to add the "-h" option to suppress default prefixes - Thnks.

    – AF.BJ
    11 hours ago











  • @AF.BJ since this answer solved your problem, consider accepting it: What should I do when someone answers my question?

    – muru
    2 hours ago


















3














Adding an array doesn't particularly help: you still would need to loop over the elements of the array (see How do I test if an item is in a bash array?):



while read -r lo; do
for keyword in "$keywords[@]"; do
if [[ $lo == *$keyword* ]]; then
echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
fi
done
done < "$i"


It might be better to use a case statement:



while read -r lo; do
case $lo in
*(ID|Instance|NOT|AI|Sitting)*)
echo "$lo" >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
;;
esac
done < "$i"


(I assume you do further processing of these lines within the loop. If not, grep or awk could do this more efficiently.)






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',
    autoActivateHeartbeat: false,
    convertImagesToLinks: false,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );






    AF.BJ is a new contributor. Be nice, and check out our Code of Conduct.









    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f511636%2fbash-looping-through-array-in-nested-for-while-if-statements%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    5














    It looks like you want to get all the lines that contains at least one out of a set of words, from a set of files.



    Assuming that you don't have many thousands of files, you could do that with a single grep command:



    grep -wE '(ID|Instance|NOT|AI|Sitting)' ./*merged >outputfile


    This would extract the lines matching any of the words listed in the pattern from the files whose names matches *merged.



    The -w with grep ensures that the given strings are not matched as substrings (i.e. NOT will not be matched in NOTICE). The -E option enables the alternation with | in the pattern.



    Add the -h option to the command if you don't want the names of the files containing matching lines in the output.



    If you do have many thousands of files, the above command may fail due to expanding to a too long command line. In that case, you may want to do something like



    for file in ./*merged; do
    grep -wE '(ID|Instance|NOT|AI|Sitting)' "$file"
    done >outputfile


    which would run the grep command once on each file, or,



    find . -maxdepth 1 -type f -name '*merged' 
    -exec grep -wE '(ID|Instance|NOT|AI|Sitting)' + >outputfile


    which would do as few invocations of grep as possible with as many files as possible at once.



    Related:



    • Why is using a shell loop to process text considered bad practice?





    share|improve this answer




















    • 1





      It is indeed a file-set of a few thousand. Originally, I built other processes into the loop but running grep separately - before the extra tweakings - it's a cleaner solution. Just needed to add the "-h" option to suppress default prefixes - Thnks.

      – AF.BJ
      11 hours ago











    • @AF.BJ since this answer solved your problem, consider accepting it: What should I do when someone answers my question?

      – muru
      2 hours ago















    5














    It looks like you want to get all the lines that contains at least one out of a set of words, from a set of files.



    Assuming that you don't have many thousands of files, you could do that with a single grep command:



    grep -wE '(ID|Instance|NOT|AI|Sitting)' ./*merged >outputfile


    This would extract the lines matching any of the words listed in the pattern from the files whose names matches *merged.



    The -w with grep ensures that the given strings are not matched as substrings (i.e. NOT will not be matched in NOTICE). The -E option enables the alternation with | in the pattern.



    Add the -h option to the command if you don't want the names of the files containing matching lines in the output.



    If you do have many thousands of files, the above command may fail due to expanding to a too long command line. In that case, you may want to do something like



    for file in ./*merged; do
    grep -wE '(ID|Instance|NOT|AI|Sitting)' "$file"
    done >outputfile


    which would run the grep command once on each file, or,



    find . -maxdepth 1 -type f -name '*merged' 
    -exec grep -wE '(ID|Instance|NOT|AI|Sitting)' + >outputfile


    which would do as few invocations of grep as possible with as many files as possible at once.



    Related:



    • Why is using a shell loop to process text considered bad practice?





    share|improve this answer




















    • 1





      It is indeed a file-set of a few thousand. Originally, I built other processes into the loop but running grep separately - before the extra tweakings - it's a cleaner solution. Just needed to add the "-h" option to suppress default prefixes - Thnks.

      – AF.BJ
      11 hours ago











    • @AF.BJ since this answer solved your problem, consider accepting it: What should I do when someone answers my question?

      – muru
      2 hours ago













    5












    5








    5







    It looks like you want to get all the lines that contains at least one out of a set of words, from a set of files.



    Assuming that you don't have many thousands of files, you could do that with a single grep command:



    grep -wE '(ID|Instance|NOT|AI|Sitting)' ./*merged >outputfile


    This would extract the lines matching any of the words listed in the pattern from the files whose names matches *merged.



    The -w with grep ensures that the given strings are not matched as substrings (i.e. NOT will not be matched in NOTICE). The -E option enables the alternation with | in the pattern.



    Add the -h option to the command if you don't want the names of the files containing matching lines in the output.



    If you do have many thousands of files, the above command may fail due to expanding to a too long command line. In that case, you may want to do something like



    for file in ./*merged; do
    grep -wE '(ID|Instance|NOT|AI|Sitting)' "$file"
    done >outputfile


    which would run the grep command once on each file, or,



    find . -maxdepth 1 -type f -name '*merged' 
    -exec grep -wE '(ID|Instance|NOT|AI|Sitting)' + >outputfile


    which would do as few invocations of grep as possible with as many files as possible at once.



    Related:



    • Why is using a shell loop to process text considered bad practice?





    share|improve this answer















    It looks like you want to get all the lines that contains at least one out of a set of words, from a set of files.



    Assuming that you don't have many thousands of files, you could do that with a single grep command:



    grep -wE '(ID|Instance|NOT|AI|Sitting)' ./*merged >outputfile


    This would extract the lines matching any of the words listed in the pattern from the files whose names matches *merged.



    The -w with grep ensures that the given strings are not matched as substrings (i.e. NOT will not be matched in NOTICE). The -E option enables the alternation with | in the pattern.



    Add the -h option to the command if you don't want the names of the files containing matching lines in the output.



    If you do have many thousands of files, the above command may fail due to expanding to a too long command line. In that case, you may want to do something like



    for file in ./*merged; do
    grep -wE '(ID|Instance|NOT|AI|Sitting)' "$file"
    done >outputfile


    which would run the grep command once on each file, or,



    find . -maxdepth 1 -type f -name '*merged' 
    -exec grep -wE '(ID|Instance|NOT|AI|Sitting)' + >outputfile


    which would do as few invocations of grep as possible with as many files as possible at once.



    Related:



    • Why is using a shell loop to process text considered bad practice?






    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited 13 hours ago

























    answered 15 hours ago









    KusalanandaKusalananda

    141k17262438




    141k17262438







    • 1





      It is indeed a file-set of a few thousand. Originally, I built other processes into the loop but running grep separately - before the extra tweakings - it's a cleaner solution. Just needed to add the "-h" option to suppress default prefixes - Thnks.

      – AF.BJ
      11 hours ago











    • @AF.BJ since this answer solved your problem, consider accepting it: What should I do when someone answers my question?

      – muru
      2 hours ago












    • 1





      It is indeed a file-set of a few thousand. Originally, I built other processes into the loop but running grep separately - before the extra tweakings - it's a cleaner solution. Just needed to add the "-h" option to suppress default prefixes - Thnks.

      – AF.BJ
      11 hours ago











    • @AF.BJ since this answer solved your problem, consider accepting it: What should I do when someone answers my question?

      – muru
      2 hours ago







    1




    1





    It is indeed a file-set of a few thousand. Originally, I built other processes into the loop but running grep separately - before the extra tweakings - it's a cleaner solution. Just needed to add the "-h" option to suppress default prefixes - Thnks.

    – AF.BJ
    11 hours ago





    It is indeed a file-set of a few thousand. Originally, I built other processes into the loop but running grep separately - before the extra tweakings - it's a cleaner solution. Just needed to add the "-h" option to suppress default prefixes - Thnks.

    – AF.BJ
    11 hours ago













    @AF.BJ since this answer solved your problem, consider accepting it: What should I do when someone answers my question?

    – muru
    2 hours ago





    @AF.BJ since this answer solved your problem, consider accepting it: What should I do when someone answers my question?

    – muru
    2 hours ago













    3














    Adding an array doesn't particularly help: you still would need to loop over the elements of the array (see How do I test if an item is in a bash array?):



    while read -r lo; do
    for keyword in "$keywords[@]"; do
    if [[ $lo == *$keyword* ]]; then
    echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
    fi
    done
    done < "$i"


    It might be better to use a case statement:



    while read -r lo; do
    case $lo in
    *(ID|Instance|NOT|AI|Sitting)*)
    echo "$lo" >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
    ;;
    esac
    done < "$i"


    (I assume you do further processing of these lines within the loop. If not, grep or awk could do this more efficiently.)






    share|improve this answer



























      3














      Adding an array doesn't particularly help: you still would need to loop over the elements of the array (see How do I test if an item is in a bash array?):



      while read -r lo; do
      for keyword in "$keywords[@]"; do
      if [[ $lo == *$keyword* ]]; then
      echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
      fi
      done
      done < "$i"


      It might be better to use a case statement:



      while read -r lo; do
      case $lo in
      *(ID|Instance|NOT|AI|Sitting)*)
      echo "$lo" >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
      ;;
      esac
      done < "$i"


      (I assume you do further processing of these lines within the loop. If not, grep or awk could do this more efficiently.)






      share|improve this answer

























        3












        3








        3







        Adding an array doesn't particularly help: you still would need to loop over the elements of the array (see How do I test if an item is in a bash array?):



        while read -r lo; do
        for keyword in "$keywords[@]"; do
        if [[ $lo == *$keyword* ]]; then
        echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
        fi
        done
        done < "$i"


        It might be better to use a case statement:



        while read -r lo; do
        case $lo in
        *(ID|Instance|NOT|AI|Sitting)*)
        echo "$lo" >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
        ;;
        esac
        done < "$i"


        (I assume you do further processing of these lines within the loop. If not, grep or awk could do this more efficiently.)






        share|improve this answer













        Adding an array doesn't particularly help: you still would need to loop over the elements of the array (see How do I test if an item is in a bash array?):



        while read -r lo; do
        for keyword in "$keywords[@]"; do
        if [[ $lo == *$keyword* ]]; then
        echo $lo >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
        fi
        done
        done < "$i"


        It might be better to use a case statement:



        while read -r lo; do
        case $lo in
        *(ID|Instance|NOT|AI|Sitting)*)
        echo "$lo" >> ~/Desktop/test_result.txt && KEY_COUNT="`expr $KEY_COUNT + 1`"
        ;;
        esac
        done < "$i"


        (I assume you do further processing of these lines within the loop. If not, grep or awk could do this more efficiently.)







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 17 hours ago









        murumuru

        37.4k589164




        37.4k589164




















            AF.BJ is a new contributor. Be nice, and check out our Code of Conduct.









            draft saved

            draft discarded


















            AF.BJ is a new contributor. Be nice, and check out our Code of Conduct.












            AF.BJ is a new contributor. Be nice, and check out our Code of Conduct.











            AF.BJ is a new contributor. Be nice, and check out our Code of Conduct.














            Thanks for contributing an answer to Unix & Linux Stack Exchange!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f511636%2fbash-looping-through-array-in-nested-for-while-if-statements%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            How to make RAID controller rescan devices The 2019 Stack Overflow Developer Survey Results Are InLSI MegaRAID SAS 9261-8i: Disk isn't recognized after replacementHow to monitor the hard disk status behind Dell PERC H710 Raid Controller with CentOS 6?LSI MegaRAID - Recreate missing RAID 1 arrayext. 2-bay USB-Drive with RAID: btrfs RAID vs built-in RAIDInvalid SAS topologyDoes enabling JBOD mode on LSI based controllers affect existing logical disks/arrays?Why is there a shift between the WWN reported from the controller and the Linux system?Optimal RAID 6+0 Setup for 40+ 4TB DisksAccidental SAS cable removal

            Free operad over a monoid object The 2019 Stack Overflow Developer Survey Results Are InAn interpretation of this construction giving an operad from a bialgebra?What is the free monoidal category generated by a monoid?Unitalization internal to monoidal categoriesCorrespondence between operads and $infty$-operads with one objectCorrespondence between operads and monads requires tensor distribute over coproduct?understanding the definition of $infty$-operad of module objectsReference for “multi-monoidal categories”When is a quasicategory over $N(Delta)^op$ a planar $infty$-operad?An interpretation of this construction giving an operad from a bialgebra?$H$-space structure on coloured algebrasTwo monoidal structures and copowering

            Србија Садржај Етимологија Географија Историја Политички систем и уставно-правно уређење Становништво Привреда Образовање Култура Спорт Државни празници Галерија Напомене Референце Литература Спољашње везе Мени за навигацију44°48′N 20°28′E / 44.800° СГШ; 20.467° ИГД / 44.800; 20.46744°48′N 20°28′E / 44.800° СГШ; 20.467° ИГД / 44.800; 20.467ууРезултати пописа 2011. према старости и полуу„Положај, рељеф и клима”„Europe: Serbia”„Основни подаци”„Gross domestic product based on purchasing-power-parity (PPP) valuation of country GDP”„Human Development Report 2018 – "Human Development Indices and Indicators 6”„Устав Републике Србије”Правопис српскога језикаGoogle DriveComparative Hungarian Cultural StudiesCalcium and Magnesium in Groundwater: Occurrence and Significance for Human Health„UNSD — Methodology”„Процене становништва | Републички завод за статистику Србије”The Age of Nepotism: Travel Journals and Observations from the Balkans During the Depression„The Serbian Revolution and the Serbian State”„Устав Србије”„Serbia a few steps away from concluding WTO accession negotiations”„A credible enlargement perspective for and enhanced EU engagement with the Western Balkans”„Freedom in the World 2017”„Serbia: On the Way to EU Accession”„Human Development Indices and Indicators: 2018 Statistical Update”„2018 Social Progress Index”„Global Peace Index”Sabres of Two Easts: An Untold History of Muslims in Eastern Europe, Their Friends and Foes„Пројекат Растко—Лузица”„Serbia: Introduction”„Serbia”оригинала„The World Factbook: Serbia”„The World Factbook: Kosovo”„Border Police Department”„Uredba o kontroli prelaska administrativne linije prema Autonomnoj pokrajini Kosovo i Metohija”оригиналаIvana Carevic, Velimir Jovanovic, STRATIGRAPHIC-STRUCTURAL CHARACTERISTICS OF MAČVA BASIN, UDC 911.2:551.7(497.11), pp. 1Archived„About the Carpathians – Carpathian Heritage Society”оригинала„O Srbiji”оригинала„Статистички годишњак Србије, 2009: Географски прегледГеографија за осми разред основне школе„Отворена, електронска база едукационих радова”„Влада Републике Србије: Положај, рељеф и клима”„Копрен (Стара планина)”„Туристичка дестинација-Србија”„Висина водопада”„РХМЗ — Републички Хидрометеоролошки завод Србије Кнеза Вишеслава 66 Београд”„Фауна Србије”„Српске шуме на издисају”„Lepih šest odsto Srbije”„Илустрована историја Срба — Увод”„Винчанска култура - Градска општина Гроцка”„''„Винча — Праисторијска метропола”''”оригиналаЈужни Словени под византијском влашћу (600—1025)Држава маћедонских Словена„Карађорђе истина и мит, Проф. др Радош Љушић, Вечерње новости, фељтон, 18 наставака, 24. август - 10. септембар 2003.”„Политика: Како је утврђена војна неутралност, 13. јануар. 2010, приступљено децембра 2012.”„Србија и РС оживеле Дејтонски споразум”„Са српским пасошем у 104 земље”Војска Србије | О Војсци | Војска Србије — Улога, намена и задациАрхивираноВојска Србије | ОрганизацијаАрхивираноОдлука о изради Стратегије просторног развоја Републике Србије до 2020. годинеЗакон о територијалној организацији Републике СрбијеЗакон о државној управиНајчешће постављана питања.„Смањење броја статистичких региона кроз измене Закона о регионалном развоју”„2011 Human development Report”„Službena upotreba jezika i pisama”„Попис становништва, домаћинстава и станова 2011. године у Републици Србији. Књига 4: Вероисповест, матерњи језик и национална припадност”„Вероисповест, матерњи језик и национална”„Специјална известитељка УН за слободу религије и вероисповести Асма Јахангир, код Заштитника грађана Саше Јанковића”„Закон о државним и другим празницима у Републици Србији”„Веронаука у српским школама”„Serbia – Ancestral Genography Atlas”Бела књига Милошевићеве владавинеоригиналаGross domestic product based on purchasing-power-parity (PPP) per capita GDP БДП 2007—2013Актуелни показатељи — Република Србија„Попис становништва, домаћинстава и станова 2011. године у Републици Србији Књига 7: Економска активност”Zemlje kandidati za članstvo u EU„Putin drops South Stream gas pipeline to EU, courts Turkey”„„Соко — историјат””оригинала„„Рембас — историјат””оригинала„„Лубница — историјат””оригинала„„Штаваљ — Историјат””оригинала„„Боговина — историјат””оригинала„„Јасеновац — историјат””оригинала„„Вршка чука — историјат””оригинала„„Ибарски рудници — историјат””оригинала„Закон о просторном плану Републике Србије од 2010 до 2020”„Кривични законик — Недозвољена изградња нуклеарних постројења, члан 267”„Б92: Srbija uklonila obogaćeni uranijum, 25. октобар 2011”„Коришћење енергије ветра у Србији — природни услови и практична примена”„Енергија ветра”„Србија може да прави струју од сунца, биомасе, воде и ветра”„Моја електрана и друге ветрењаче”„Биомаса, струја без инвестиција”„Auto-karte Srbije”„www.srbija.gov.rs Статистике о Србији”оригинала„Статистика зе месец децембар и 2016. годину”„Turizam u Srbiji”„Univerzitet u Beogradu: Vek i po akademskog znanja”„Vojnomedicinska akademija: 165 godina tradicije i napretka”Никола Гиљен, Соња Јовићевић Јов и Јелена Мандић: Мирослављево јеванђеље; Текст је публикован у ревији „Историја” и настао је као део научно-истраживачког рада Фонда „Принцеза Оливера”„World music асоцијација Србије”оригинала„World music у Србији”оригинала„Pogledajte: Boban Marković svira u redakciji „Blica”!”„Eurovision Song Contest 2007 Final”„Projekat Rastko, Alojz Ujes: Joakim Vujic”„Унеско”„Списак локалитета Светске баштине”„Guča i Egzit zaludeli svet”оригинала„Sabor trubača GUČA”„Interesting facts about Exit”оригинала„FIFA Association Information”„Serbia women win EuroBasket title, gain first Olympics berth”„Odbojkašice ispisale istoriju – Srbija je svetski prvak!”„Сајт Ватерполо савеза Србије, Освојене медаље”„Сајт ФК Црвена звезда, Бари”„Сајт ФК Црвена звезда, Токио”„Blic:Zlatna Milica! Mandićeva donela Srbiji najsjajnije odličje u Londonu!”„Милица Мандић освојила златну медаљу („Политика”, 12. август 2012)”„Златни Давор Штефанек”„DŽUDO ŠAMPIONAT Majdov osvojio svetsko zlato”„Španovićeva trećim skokom svih vremena do zlata!”„Чудо Иване Шпановић — 7,24 м („Политика”, 5. март 2017)”The Age of Nepotism: Travel Journals and Observations from the Balkans During the DepressionCalcium and Magnesium in Groundwater: Occurrence and Significance for Human HealthComparative Hungarian Cultural StudiesБела књига Милошевићеве владавинеоригиналаComparative Hungarian Cultural StudiesSabres of Two Easts: An Untold History of Muslims in Eastern Europe, Their Friends and FoesГеографија за осми разред основне школеSerbia: the country, people, life, customsМедијиВодичПодациВлада Републике СрбијеНародна скупштина Републике СрбијеНародна канцеларија председника Републике СрбијеНародна банка СрбијеТуристичка организација СрбијеПортал еУправе Републике СрбијеРепубличко јавно правобранилаштвоууууууWorldCat151202876n851959190000 0000 9526 67094054598-24101000570825ge130919