Linux - 循环遍历每一行的每个元素

时间:2021-04-16 12:35:00

标签: for-loop awk grep

我有一个包含以下信息的文本文件:

cat test.txt
a,e,c,d,e,f,g,h
d,A,e,f,g,h

我希望遍历每一行,然后为每一行打印与 e 不同的所有字符的索引。所以理想的输出要么是制表符分隔符,要么是逗号分隔符

1 3 4 6 7 8
1 2 4 5 6

or

1,3,4,6,7,8
1,2,4,5,6

我设法遍历每一行并打印索引,但结果被打印到同一行而不是分开的。

while read line;do echo "$line" | awk -F, -v ORS=' ' '{for(i=1;i<=NF;i++) if($i!="e") {print i}}' ;done<test.txt

结果是

1 3 4 6 7 8 1 2 4 5 6

如果我只使用 awk awk -F, -v ORS=' ' '{for(i=1;i<=NF;i++) if($i!="e") {print i}}'

我得到相同的输出

任何人都可以帮助我解决这个分隔线的具体问题。

1 个答案:

答案 0 :(得分:5)

如果你不介意一些尾随空格,你可以这样做:

while read line;do echo "$line" | awk -F, '{for(i=1;i<=NF;i++) if($i!="e") {printf i " "}; print ""}' ;done<test.txt

但是省略while循环并执行以下操作会更典型:

awk -F, '{for(i=1;i<=NF;i++) if($i!="e") {printf i " "}; print ""}' <test.txt

你可以用稍微有点神秘的方式避免尾随空格:

awk -F, '{m=0; for(i=1;i<=NF;i++) if($i!="e") {printf "%c%d", m++ ? " " : "", i }; print ""}' <test.txt
相关问题