1

我必须解析以下格式的文件:

line1_param1:line1_param2:line1_param3:
line1_param2:line2_param2:line2_param3:
line1_param3:line3_param2:line3_param3:

并逐行处理,从当前行中提取所有参数。目前我已经以这种方式管理它:

IFS=":"
grep "nice" some_file | sort > tmp_file
while read param1 param2 param3
do
  ..code here..
done < tmp_file
unset IFS

如何避免创建临时文件?

不幸的是,这不能正常工作:

IFS=":"
while read param1 param2 param3
do
  ..code here..
done <<< $(grep "nice" some_file | sort)
unset IFS

因为整行都分配给了 param1。

4

2 回答 2

6

您可以为此使用流程替换

while IFS=: read -r param1 param2 param3
do
   echo "Any code here to process: $param1 $param2 $param3"
done < <(grep "nice" some_file | sort)
于 2014-09-03T07:39:47.900 回答
3

如果您使用的是bash4.2 或更高版本,则可以启用lastpipe使用“自然”管道的选项。循环将while在当前 shell 中执行,而不是在子 shell 中执行,因此您设置或更改的变量在管道之后仍然可见。(从 anubhava 的优秀答案中窃取代码以进行演示。)

shopt -s lastpipe
grep "nice" some_file | sort | while IFS=: read -r param1 param2 param3
do
   echo "Any code here to process: $param1 $param2 $param3"
done
于 2014-09-03T12:54:19.770 回答