为什么 Solaris 5.10 上的 GNU GAWK 3.1.5 与模式不匹配?

Why GNU GAWK 3.1.5 on Solaris 5.10 does not match the pattern?

我正在通过 awk 解析 SFTP 'ls -l' 输出,只打印现有目录的结果(是的,我知道 Python 更好,解析 ls 不是个好主意,技术任务限制)。这是我收到的输出:

bash-3.2$ sftp my-server < batch_ls.sftp | gawk 'BEGIN{d=-1;wd=1}/^sftp> c/{d++;wd=0}/Coul/{wd=1}wd==0{print [=10=],d,wd}'

Connecting to my-server...
sftp> cd /ik/sftp_source/alpha 0 0
sftp> ls -l 0 0
drwxr-xr-x    2 65740    102          4096 Mar 21 05:15 . 0 0
drwxr-xr-x    4 65740    102          4096 Mar 21 04:21 .. 0 0
-rw-r--r--    1 65740    102            35 Mar 21 05:15 0452984832A8.234 0 0
-rw-r--r--    1 65740    102            34 Mar 21 05:15 0989855744A8.234 0 0
-rw-r--r--    1 65740    102            35 Mar 21 05:15 1258291200A8.234 0 0
-rw-r--r--    1 65740    102            34 Mar 21 05:15 1862270976A8.234 0 0
sftp> cd /ik/sftp_source/belta 1 0
Couldn't canonicalise: No such file or directory
sftp> ls -l 1 0
drwxr-xr-x    2 65740    102          4096 Mar 21 05:15 . 1 0
drwxr-xr-x    4 65740    102          4096 Mar 21 04:21 .. 1 0
-rw-r--r--    1 65740    102            35 Mar 21 05:15 0452984832A8.234 1 0
-rw-r--r--    1 65740    102            34 Mar 21 05:15 0989855744A8.234 1 0
-rw-r--r--    1 65740    102            35 Mar 21 05:15 1258291200A8.234 1 0
-rw-r--r--    1 65740    102            34 Mar 21 05:15 1862270976A8.234 1 0
sftp> cd /ik/sftp_source/delta 2 0
sftp> ls -l 2 0
drwxr-xr-x    2 65740    102          4096 Mar 21 05:15 . 2 0
drwxr-xr-x    4 65740    102          4096 Mar 21 04:21 .. 2 0
-rw-r--r--    1 65740    102            34 Mar 21 05:15 0335544320A8.234 2 0
-rw-r--r--    1 65740    102            35 Mar 21 05:15 0419430400A8.234 2 0
-rw-r--r--    1 65740    102            35 Mar 21 05:15 1073741824A8.234 2 0
-rw-r--r--    1 65740    102            34 Mar 21 05:15 1392508928A8.234 2 0

这里:

它似乎没有捕捉到字符串的“Couldn't”部分。谁能帮我想出一个更好的解决方案并解释为什么会这样?非常感谢!

PS 请注意,"Couldn't canonicalise..." 行末尾没有附加 d 和 wd 值。

管道后面的命令部分看不到这些行,因为您正在重定向 stdoutsftp 正在将错误发送到 stderr

如果你想将它们都重定向到 gawk,你应该将 2>&1 添加到你的命令中:

bash-3.2$ sftp my-server < batch_ls.sftp 2>&1 | gawk 'BEGIN{d=-1;wd=1}/^sftp> c/{d++;wd=0}/Coul/{wd=1}wd==0{print [=10=],d,wd}'