Linux 将命令输出存储到shell脚本中的数组
我正在使用ssh连接到远程机器,并在那里读取日志文件。从该日志文件中,基于一些标记,我提取特定日志并将其存储在变量中。每个日志都在日志文件的新行中,数据可以包含任何字符,包括空格Linux 将命令输出存储到shell脚本中的数组,linux,bash,shell,unix,Linux,Bash,Shell,Unix,我正在使用ssh连接到远程机器,并在那里读取日志文件。从该日志文件中,基于一些标记,我提取特定日志并将其存储在变量中。每个日志都在日志文件的新行中,数据可以包含任何字符,包括空格 array=("$(egrep "UserComments/propagateBundle-2013-10-19--04:42:13|UserComments/propagateBundle-2013-10-19--04:38:36|UserComments/propagateBundle-2013-10-19--04
array=("$(egrep "UserComments/propagateBundle-2013-10-19--04:42:13|UserComments/propagateBundle-2013-10-19--04:38:36|UserComments/propagateBundle-2013-10-19--04:34:24" <path>/propagateBundle.log)")
echo ${array[0]}
echo "$array"
但在屏幕上回显“max”会产生“1”。如何将输出保存在数组中?我也试过使用
IFS=\`\n`
但无法获取数组中的数据
编辑
我使用了阿努巴夫给出的解决方案,效果很好。现在我面临第二个问题。因为我的数据包含空格,所以数组在空格处中断,错误地将一条注释包含为多个数组。所以,我用
IFS=\`\n`
并且在反勾号之前还使用了$
符号。虽然这解决了我的问题,但我仍然在日志中看到一个异常:
test.sh: line 11: n: command not found
有什么建议吗?不要在命令替换中加引号:
array=( $(egrep "UserComments/propagateBundle-2013-10-19--04:42:13|UserComments/propagateBundle-2013-10-19--04:38:36|UserComments/propagateBundle-2013-10-19--04:34:24" <path>/propagateBundle.log) )
array=($(egrep“UserComments/propagateBundle-2013-10-19--04:42:13 | UserComments/propagateBundle-2013-10-19--04:38:36 | UserComments/propagateBundle-2013-10-19--04:34:24”/propagateBundle.log))
代码中的引号将整个输出视为数组中的单个字符串。我使用了IFS=('\n'),否则所有“n”字符将从结果中消失,并且sort命令无法正常工作。见下文,这是一个定制的llq输出
#!/bin/bash
IFS=('\n')
raw=(`llq -f %id %o %gu %gl %st %BS %c`)
echo
echo ${raw[*]} | grep "step(s)"
echo
echo ${raw[*]} | grep "Step"
echo ${raw[*]} | grep "\---*"
echo ${raw[*]} | grep "bgp-fn*" | sort -k5 -r
echo ${raw[*]} | grep "\---*"
echo ${raw[*]} | grep "Step"
echo
echo ${raw[*]} | grep "step(s)"
echo
感谢阿努巴瓦的热情回应。请看我编辑的帖子。第二部分现在导致了一个问题。您正在使用反引号,这是
$(…)
的旧式同义词。最简单的方法是IFS=$'\n'
(单引号前加一个美元符号)。@chepner谢谢你的朋友!!!!这确实奏效了!!!非常感谢。。。。
#!/bin/bash
IFS=('\n')
raw=(`llq -f %id %o %gu %gl %st %BS %c`)
echo
echo ${raw[*]} | grep "step(s)"
echo
echo ${raw[*]} | grep "Step"
echo ${raw[*]} | grep "\---*"
echo ${raw[*]} | grep "bgp-fn*" | sort -k5 -r
echo ${raw[*]} | grep "\---*"
echo ${raw[*]} | grep "Step"
echo
echo ${raw[*]} | grep "step(s)"
echo