Как создать bash-скрипт, который может извлекать строки из массива?

Как создать bash-скрипт, который может извлекать строки из массива?

У меня возникла дилемма: я пытаюсь написать скрипт 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.

Связанный контент