У меня возникла дилемма: я пытаюсь написать скрипт Linux bash, который бы извлекал каждую строку из массива и обрабатывал результат.
IE
var=("string one" "string two" "string three")
Как бы я использовал цикл for для извлечения каждой строки, учитывая, что в строках есть пробелы, поэтому мне нужно было бы извлечь всю строку, т. е. «строку три», а затем в этом цикле fo обработать результат.
НАПРИМЕР
#! /bin/bash
clear
SimName=("Welcome" "Testing Region")
echo
echo
echo
echo
#cd dreamgrid/Opensim/bin
# for loop goes here
# processing below
#screen -S "$SimName" -d -m mono OpenSim.exe -inidirectory="Regions/$SimName" # Needs altering to process each string
#sleep 2
#screen -r "$SimName" # Needs chaging to show each string in turn.
# echo $SimName[1] # something test to it with, but needs changing to show each string in turn.
В Бейсике это просто:
DIM A$(2)
A$(1) = "string one"
A$(2) = "string two"
FOR A=1 to 2
C$=A$(A)
FOR DL=1 TO 2000
NEXT
PRINT C$
NEXT
решение1
Синтаксис:
for val in "${arr[@]}"; do
# something with "$val"
done
бывший.
$ arr=("string one" "string two" "string three")
$ for val in "${arr[@]}"; do printf '%s\n' "$val"; done
string one
string two
string three
Двойные кавычки "${arr[@]}"
позволяют корректно обрабатывать элементы, содержащие пробелы (или, в более общем смысле, символы из текущего IFS
). Из man bash
:
If the word is double-quoted, ${name[*]} expands to a single word with the value of each array member separated by the first character of the IFS special variable, and ${name[@]} expands each element of name to a sep‐ arate word.