2013-10-21 126 views
4

我使用ssh连接到远程计算机并在那里读取日志文件。从该日志文件中,基于某些标记,我提取特定的日志并将其存储在一个变量中。每个日志都在日志文件中换行,数据可以包含任何字符,包括空格。将命令输出存储到shell脚本中的数组

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" 

第一个回波在一行中用白色空格分隔输出完整的输出,而另一行则在新行中输出输出。问题是,我无法将此输出保存为数组。我试过这个:

newArray=("$array") 
max=${#newArray[@]} 
echo $max 

但是回显'max'会在屏幕上产生'1'。如何将输出保存到数组中?我也试过使用

IFS=\`\n` 

但是无法获得数组中的数据。

编辑

我使用Anubhav给出的解决方案,它的工作就像魅力。现在我面临第二个问题。由于我的数据包含空格,因此数组在一个空格处打破,并且错误地将一个注释包含为多个数组。所以,我用

IFS=\`\n` 

并且在反引号之前也使用了$符号。虽然这解决了我的问题,但我仍然在日志中发现异常:

test.sh: line 11: n: command not found 

有什么建议吗?

+1

您正在使用反引号,它是'$(...)'的旧式同义词。最简单的方法是'IFS = $'\ n''(单引号前加一个美元符号)。 – chepner

+0

@chepner感谢一位好朋友!!!!这确实有效!非常感谢.... – Adi

回答

2

不要把引号中的命令替换:

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)) 

,随着行情在你的代码全部输出将被视为数组中单个字符串。

+0

非常感谢Anubhava的回应。请参阅我编辑的帖子。第二部分现在造成问题。 – Adi

0

我已经使用了IFS =('\ n'),否则所有的“n”个字符都会从结果中消失,排序命令无法正常工作。见下图,这是一个定制的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 
相关问题