जवाबों:
आप इसे इस तरह से उपयोग कर सकते हैं:
## declare an array variable
declare -a arr=("element1" "element2" "element3")
## now loop through the above array
for i in "${arr[@]}"
do
echo "$i"
# or do whatever with individual element of the array
done
# You can access them using echo "${arr[0]}", "${arr[1]}" also
मल्टी-लाइन ऐरे डिक्लेरेशन के लिए भी काम करता है
declare -a arr=("element1"
"element2" "element3"
"element4"
)
यह संभव है, निश्चित रूप से।
for databaseName in a b c d e f; do
# do something like: echo $databaseName
done
देखें , के लिए बैश लूप्स जबकि और जब तक जानकारी के लिए।
for year in $(seq 2000 2013)
।
DATABASES="a b c d e f"
।
उन उत्तरों में से कोई भी एक काउंटर शामिल नहीं है ...
#!/bin/bash
## declare an array variable
declare -a array=("one" "two" "three")
# get length of an array
arraylength=${#array[@]}
# use for loop to read all values and indexes
for (( i=1; i<${arraylength}+1; i++ ));
do
echo $i " / " ${arraylength} " : " ${array[$i-1]}
done
आउटपुट:
1 / 3 : one
2 / 3 : two
3 / 3 : three
echo "$i / ${arraylength} : ${array[$i-1]}"
- अन्यथा, यदि आपके $i
ग्लोब में यह विस्तारित होगा, यदि इसमें एक टैब है तो इसे बदल दिया जाएगा। एक स्थान, आदि
हाँ
for Item in Item1 Item2 Item3 Item4 ;
do
echo $Item
done
आउटपुट:
Item1
Item2
Item3
Item4
रिक्त स्थान को संरक्षित करने के लिए; एकल या डबल उद्धरण सूची प्रविष्टियाँ और डबल उद्धरण सूची विस्तार।
for Item in 'Item 1' 'Item 2' 'Item 3' 'Item 4' ;
do
echo "$Item"
done
आउटपुट:
Item 1
Item 2
Item 3
Item 4
कई लाइनों पर सूची बनाने के लिए
for Item in Item1 \
Item2 \
Item3 \
Item4
do
echo $Item
done
आउटपुट:
Item1
Item2
Item3
Item4
सरल सूची चर
List=( Item1 Item2 Item3 )
या
List=(
Item1
Item2
Item3
)
सूची चर प्रदर्शित करें:
echo ${List[*]}
आउटपुट:
Item1 Item2 Item3
सूची के माध्यम से लूप:
for Item in ${List[*]}
do
echo $Item
done
आउटपुट:
Item1
Item2
Item3
एक सूची के माध्यम से जाने के लिए एक समारोह बनाएँ:
Loop(){
for item in ${*} ;
do
echo ${item}
done
}
Loop ${List[*]}
सूची बनाने के लिए घोषित कीवर्ड (कमांड) का उपयोग करना, जिसे तकनीकी रूप से एक सरणी कहा जाता है:
declare -a List=(
"element 1"
"element 2"
"element 3"
)
for entry in "${List[@]}"
do
echo "$entry"
done
आउटपुट:
element 1
element 2
element 3
एक सहयोगी सरणी बनाना। एक शब्दकोष:
declare -A continent
continent[Vietnam]=Asia
continent[France]=Europe
continent[Argentina]=America
for item in "${!continent[@]}";
do
printf "$item is in ${continent[$item]} \n"
done
आउटपुट:
Argentina is in America
Vietnam is in Asia
France is in Europe
सूची में सीवीएस चर या फाइलें ।
आंतरिक क्षेत्र विभाजक को किसी स्थान से बदलना, जो आप चाहते हैं।
नीचे दिए गए उदाहरण में इसे अल्पविराम में बदल दिया गया है
List="Item 1,Item 2,Item 3"
Backup_of_internal_field_separator=$IFS
IFS=,
for item in $List;
do
echo $item
done
IFS=$Backup_of_internal_field_separator
आउटपुट:
Item 1
Item 2
Item 3
यदि उन्हें संख्या देने की आवश्यकता है:
`
इसे बैक टिक कहा जाता है। वापस टिक के अंदर कमांड रखें।
`commend`
यह आपके कीबोर्ड पर या टैब कुंजी के ऊपर नंबर एक के बगल में है। एक मानक अमेरिकी अंग्रेजी भाषा कीबोर्ड पर।
List=()
Start_count=0
Step_count=0.1
Stop_count=1
for Item in `seq $Start_count $Step_count $Stop_count`
do
List+=(Item_$Item)
done
for Item in ${List[*]}
do
echo $Item
done
आउटपुट है:
Item_0.0
Item_0.1
Item_0.2
Item_0.3
Item_0.4
Item_0.5
Item_0.6
Item_0.7
Item_0.8
Item_0.9
Item_1.0
चकत्ते व्यवहार के साथ और अधिक परिचित बनना:
एक फ़ाइल में एक सूची बनाएँ
cat <<EOF> List_entries.txt
Item1
Item 2
'Item 3'
"Item 4"
Item 7 : *
"Item 6 : * "
"Item 6 : *"
Item 8 : $PWD
'Item 8 : $PWD'
"Item 9 : $PWD"
EOF
सूची और प्रदर्शन के लिए सूची फ़ाइल पढ़ें
List=$(cat List_entries.txt)
echo $List
echo '$List'
echo "$List"
echo ${List[*]}
echo '${List[*]}'
echo "${List[*]}"
echo ${List[@]}
echo '${List[@]}'
echo "${List[@]}"
BASH कमांडलाइन संदर्भ मैनुअल: शेल के लिए कुछ वर्णों या शब्दों का विशेष अर्थ।
"${List[@]}"
, सही होने की आवश्यकता है । गलत है। गलत है। कोशिश करें - आपको किसी अन्य संस्करण से नहीं बल्कि सही व्यवहार मिलेगा । ${List[@]}
${List[*]}
List=( "* first item *" "* second item *" )
for item in "${List[@]}"; do echo "$item"; done
List=( "first item" "second item" )
में विभाजित कर दिया जाएगा first
, item
, second
, item
साथ ही साथ)।
ls
आउटपुट देने के लिए प्रेरित कर सकता है ।
4ndrew के जवाब के रूप में एक ही भावना में:
listOfNames="RA
RB
R C
RD"
# To allow for other whitespace in the string:
# 1. add double quotes around the list variable, or
# 2. see the IFS note (under 'Side Notes')
for databaseName in "$listOfNames" # <-- Note: Added "" quotes.
do
echo "$databaseName" # (i.e. do action / processing of $databaseName here...)
done
# Outputs
# RA
# RB
# R C
# RD
B. नाम में कोई व्हाट्सएप नहीं:
listOfNames="RA
RB
R C
RD"
for databaseName in $listOfNames # Note: No quotes
do
echo "$databaseName" # (i.e. do action / processing of $databaseName here...)
done
# Outputs
# RA
# RB
# R
# C
# RD
टिप्पणियाँ
listOfNames="RA RB R C RD"
का समान आउटपुट है।डेटा में लाने के अन्य तरीकों में शामिल हैं:
स्टडिन से पढ़ें
# line delimited (each databaseName is stored on a line)
while read databaseName
do
echo "$databaseName" # i.e. do action / processing of $databaseName here...
done # <<< or_another_input_method_here
IFS='\n'
, या MacOS के लिए IFS='\r'
) की अनुमति देने के लिए स्क्रिप्ट में निर्दिष्ट किया जा सकता है।#!/bin/bash
स्क्रिप्ट फ़ाइल के शीर्ष पर शामिल निष्पादन पर्यावरण को इंगित करता है।अन्य स्रोत ( लूप पढ़ते समय )
IFS
। (सभी के लिए, IFS
एक विशिष्ट परिसीमा को निर्दिष्ट करने देता है, जो अन्य व्हाट्सएप को सब्सट्रेट में अलग किए बिना तार में शामिल करने की अनुमति देता है)।
$databaseName
बस पूरी सूची में शामिल है, इस प्रकार केवल एक पुनरावृत्ति करता है।
आश्चर्य है कि किसी ने इसे अभी तक पोस्ट नहीं किया है - यदि आपको सरणी के माध्यम से लूप करते समय तत्वों के सूचकांक की आवश्यकता है, तो आप यह कर सकते हैं:
arr=(foo bar baz)
for i in ${!arr[@]}
do
echo $i "${arr[i]}"
done
आउटपुट:
0 foo
1 bar
2 baz
मुझे यह "पारंपरिक" फॉर-लूप स्टाइल ( for (( i=0; i<${#arr[@]}; i++ ))
) की तुलना में बहुत अधिक सुरुचिपूर्ण लगता है ।
( ${!arr[@]}
और $i
उन्हें उद्धृत करने की आवश्यकता नहीं है क्योंकि वे सिर्फ संख्या हैं; कुछ उन्हें वैसे भी उद्धृत करने का सुझाव देंगे, लेकिन यह सिर्फ व्यक्तिगत प्राथमिकता है।)
यह भी पढ़ने में आसान है:
FilePath=(
"/tmp/path1/" #FilePath[0]
"/tmp/path2/" #FilePath[1]
)
#Loop
for Path in "${FilePath[@]}"
do
echo "$Path"
done
IFS=$'\n'
यह इस परिदृश्य में अन्य समाधानों के लिए भी काम कर सकता है।
के अलावा anubhava 'सही जवाब है: अगर पाश के लिए बुनियादी वाक्य रचना है:
for var in "${arr[@]}" ;do ...$var... ;done
में एक विशेष मामला हैदे घुमा के:
जब एक स्क्रिप्ट या एक समारोह चल रहा है, तर्क कमांड लाइन में पारित करने के लिए आवंटित किया जाएगा $@
सरणी चर, आप तक पहुंच सकते हैं $1
, $2
, $3
, और इतने पर।
इसे (परीक्षण के लिए) आबाद किया जा सकता है
set -- arg1 arg2 arg3 ...
इस सरणी पर एक लूप बस लिखा जा सकता है:
for item ;do
echo "This is item: $item."
done
ध्यान दें कि आरक्षित कार्य in
मौजूद नहीं है और कोई सरणी नाम भी नहीं है!
नमूना:
set -- arg1 arg2 arg3 ...
for item ;do
echo "This is item: $item."
done
This is item: arg1.
This is item: arg2.
This is item: arg3.
This is item: ....
ध्यान दें कि यह इसी से अधिक है
for item in "$@";do
echo "This is item: $item."
done
#!/bin/bash
for item ;do
printf "Doing something with '%s'.\n" "$item"
done
एक स्क्रिप्ट में इस सहेजें myscript.sh
, chmod +x myscript.sh
है, तो
./myscript.sh arg1 arg2 arg3 ...
Doing something with 'arg1'.
Doing something with 'arg2'.
Doing something with 'arg3'.
Doing something with '...'.
myfunc() { for item;do cat <<<"Working about '$item'."; done ; }
फिर
myfunc item1 tiem2 time3
Working about 'item1'.
Working about 'tiem2'.
Working about 'time3'.
सरल तरीका :
arr=("sharlock" "bomkesh" "feluda" ) ##declare array
len=${#arr[*]} # it returns the array length
#iterate with while loop
i=0
while [ $i -lt $len ]
do
echo ${arr[$i]}
i=$((i+1))
done
#iterate with for loop
for i in $arr
do
echo $i
done
#iterate with splice
echo ${arr[@]:0:3}
घोषित सरणी Korn शेल के लिए काम नहीं करती है। कोर्न शेल के लिए नीचे दिए गए उदाहरण का उपयोग करें:
promote_sla_chk_lst="cdi xlob"
set -A promote_arry $promote_sla_chk_lst
for i in ${promote_arry[*]};
do
echo $i
done
for i in ${foo[*]}
मूल रूप से हमेशा गलत चीज है - for i in "${foo[@]}"
वह रूप है जो मूल सूची की सीमाओं को बनाए रखता है और ग्लोब विस्तार को रोकता है। और गूंज की जरूरत हैecho "$i"
यदि आप कोर्न शेल का उपयोग कर रहे हैं, तो " सेट-ए-डेटाबेसनाम " है, अन्यथा " घोषणा-ए डेटाबेसनाम " है
सभी गोले पर काम करने वाली स्क्रिप्ट लिखने के लिए,
set -A databaseName=("db1" "db2" ....) ||
declare -a databaseName=("db1" "db2" ....)
# now loop
for dbname in "${arr[@]}"
do
echo "$dbname" # or whatever
done
यह सभी गोले पर काम होना चाहिए।
$ bash --version
GNU बैश, संस्करण 4.3.33 (0) -release (amd64-portbld-freebsd10.0) $ set -A databaseName=("db1" "db2" ....) || declare -a databaseName=("db1" "db2" ....)
bash: अप्रत्याशित टोकन के पास सिंटैक्स त्रुटि `('
इसे इस्तेमाल करे। यह काम कर रहा है और परीक्षण किया है।
for k in "${array[@]}"
do
echo $k
done
# For accessing with the echo command: echo ${array[0]}, ${array[1]}
array=( "hello world" )
, या arrray=( "*" )
; पहले मामले में यह प्रिंट hello
और world
अलग-अलग होगा, दूसरे में यह फाइलों की एक सूची प्रिंट करेगा*
सिंगल लाइन लूपिंग,
declare -a listOfNames=('db_a' 'db_b' 'db_c')
for databaseName in ${listOfNames[@]}; do echo $databaseName; done;
आपको इस तरह एक आउटपुट मिलेगा,
db_a
db_b
db_c
मैं एक git pull
अद्यतन के लिए अपनी परियोजनाओं की एक सरणी के माध्यम से पाश :
#!/bin/sh
projects="
web
ios
android
"
for project in $projects do
cd $HOME/develop/$project && git pull
end