所以,我看到了这个输出,我有点惊讶:
$ echo "a,b,c,d,e,f,g" | cut -d, -f-4
a,b,c,d
$ echo "a,b,c,d,e,f,g" | cut -d, -f6-
f,g
echo "a,b,c,d,e,f,g" | awk '{ print $0 | "cut -d, -f-4"; print $0 | "cut -d, -f6-"; }'
f,g
a,b,c,d(顺便说一句,我意识到在awk中这样做是完全愚蠢的,但这是我看到的唯一的命令!)。
据我所知,这应该将记录排入两个命令中--按顺序排列。但出于某种原因,产出似乎出现了逆转。如果我这样做
$ echo "a,b,c,d,e,f,g" | awk '{ print $0 | "echo hello"; print $0 | "echo goodbye"; }'
hello
goodbye然后一切都按我预期的顺序来了。我认为这一定是某种争用条件,但我感到惊讶的是,awk没有等待管道中的子命令完成。这是一个已知的问题,使用awk或某些东西对gawk?有什么办法可以避免这样的陷阱吗?
编辑:
我也试过用mawk ..。相同的(相反的)结果,并且似乎对两者都是一致的。
发布于 2012-04-25 16:08:59
为了确保完成外部命令,必须对该命令进行关。
$ echo "a,b,c,d,e,f,g" | awk 'BEGIN {cmd1 = "cut -d, -f-4"; cmd2 = "cut -d, -f6-"} { print $0 | cmd1; close(cmd1); print $0 | cmd2; close(cmd2)}'
a,b,c,d
f,g发布于 2012-04-25 16:09:52
我对此感到惊讶,但很明显,awk并行运行命令。试试这个:
# time echo "a,b,c,d,e,f,g" | awk '{ print $0 | "sleep 2"; print $0 | "sleep 2"; }'
real 0m2.250s
user 0m0.030s
sys 0m0.060shttps://stackoverflow.com/questions/10318922
复制相似问题