我必须解析以下格式的文件:
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。
您可以对此使用过程替换:
while IFS=: read -r param1 param2 param3
do
echo "Any code here to process: $param1 $param2 $param3"
done < <(grep "nice" some_file | sort)
如果使用bash
4.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