我必须解析以下格式的文件:
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。
您可以使用过程替代 http://tldp.org/LDP/abs/html/process-sub.html为了这:
while IFS=: read -r param1 param2 param3
do
echo "Any code here to process: $param1 $param2 $param3"
done < <(grep "nice" some_file | sort)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)