Разделить слова из `read` и сохранить в массиве?

Разделить слова из `read` и сохранить в массиве?

Как мне взять входные данные из read, разбить слова пробелами, а затем поместить эти слова в массив?

Я хочу:

$ read sentence
this is a sentence
$ echo $sentence[1]
this
$ echo $sentence[2]
is
(and so on...)

Я использую это для обработки английских предложений для текстового приключения.

решение1

Если вы используете bash, в его readкоманде есть -aсоответствующая опция.

Отhelp read

Options:
  -a array  assign the words read to sequential indices of the array
        variable ARRAY, starting at zero

Так

$ read -a s
This is a sentence.

Обратите внимание, что результирующий массив имеет индексацию ноль, поэтому

$ echo "${s[0]}"
This
$ echo "${s[1]}"
is
$ echo "${s[2]}"
a
$ echo "${s[3]}"
sentence.
$ 

решение2

Аналогичный ответ от @steeldriver

#!/bin/bash
printf "Input text:" && read UI ;
read -a UIS <<< ${UI} ;
X=0 ;
for iX in ${UIS[*]} ; do printf "position: ${X}==${iX}\n" ; ((++X)) ; done ;

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