Відповіді:
Ви можете використовувати його так:
## 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
Див Bash Loops для, в той час як і до для деталей.
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
Змінні CVS або файли у списку .
Зміна внутрішнього роздільника поля від простору до того, що вам завгодно.
У наведеному нижче прикладі він змінюється комою
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[@]}"
"${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"
має той самий вихід.Інші способи залучення даних включають:
Читайте з stdin
# 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. Використовуйте нижченаведений приклад для оболонки 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"
Якщо ви використовуєте оболонку Korn, є " встановити -A databaseName ", інакше є " оголосити -a databaseName "
Щоб написати сценарій, що працює над усіма оболонками,
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 bash, версія 4.3.33 (0) -випуск (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
Що мені справді було потрібно для цього, було щось подібне:
for i in $(the_array); do something; done
Наприклад:
for i in $(ps -aux | grep vlc | awk '{ print $2 }'); do kill -9 $i; done
(Убиває всі процеси з vlc на їх ім'я)
Я переглядаю масив своїх проектів для git pull
оновлення:
#!/bin/sh
projects="
web
ios
android
"
for project in $projects do
cd $HOME/develop/$project && git pull
end