Answers:
如果只想在每行的末尾添加数字,请执行以下操作:
numbers=( $(pdc ... | grep -oP 'okay.+?\K\d+$') )
如果要将每一行存储到数组中
mapfile -t lines < <(pdc ...)
要从数组中检索数据:
for (( i=0; i<${#numbers[@]}; i++ )); do echo ${numbers[i]}; done
echo
printf "%s\n" "${lines[@]}"
33
22
11
[okay ]: you are currently listening: 33
[okay ]: you are currently listening: 22
[okay ]: you are currently listening: 11
首先,您不一定需要数组,而是可以逐行处理输出:
pdc status -a 2>&1 | grep 'okay' | while read line; do somecommand "$line"; done
如果确实需要阵列,Glenn Jackman 已经为您提供了最佳方法,但这是另一种方法:
#!/bin/bash
IFS=$'\n'
array=($(pdc status -a 2>&1 | grep 'okay'))
说明:
$IFS=$'\n'
:$IFS
是bash的输入字段分隔符,将其设置为仅换行符(\n
)可确保您的输出行不会在空格上分割,以便您可以将每行保存为单独的数组元素。否则,命令输出中的每个单词都会是一个不同的元素。
根据您要执行的操作,保存$IFS
数组的旧值并在读取数组后还原它可能是一个好主意:
oldifs="$IFS"
IFS=$'\n'
array=($(echo -e "foo bar\nbaz bar"))
IFS="$oldifs"
$(command)
:这称为命令替换,它允许您将命令的输出保存在变量中。有两种方法可以做到这一点:
var=$(command)
和
var=`command`
在这两个中,$()
更好是因为:
它可以处理嵌套命令:
var=$(command1 $(command 2))
例如 var=$(cat $(find ~/))
它几乎没有引用问题,并且语法更简洁。看到这里更多。
使用readarray
内置的另一种更直观的方法(请参阅参考资料help -m readarray
):
readarray -t array <<< "$(pdc status -a 2>&1 | grep 'okay')"
接下来,要打印一个数组元素,假设第二个元素,您可以使用:
echo "${array[1]}"
要在单独的行上打印所有数组元素,可以使用:
printf -- "%s\n" "${array[@]}"
mapfile -t array < <(grep.....)