我想使用shebang执行一个
gawk脚本与–re-interval。 “天真”的方法
#!/usr/bin/gawk --re-interval -f ... awk script goes here
不工作,因为gawk调用第一个参数“–re-interval -f”(不分割在空格周围),它不明白。有没有解决方法?
当然,你可以不直接调用gawk,而是将其封装到一个分割第一个参数的shell脚本中,或者创建一个shell脚本,然后调用gawk并将脚本放到另一个文件中,但是我想知道是否有办法这在一个文件内。
shebang行的行为在系统之间是不同的 – 至少在Cygwin它不分割空格的参数。我只是关心如何在一个行为像这样的系统上做;该脚本并不意味着可移植。
这似乎对我工作与(g)awk。
#!/bin/sh arbitrary_long_name==0 "exec" "/usr/bin/gawk" "--re-interval" "-f" "$0" "$@" # The real awk program starts here { print $0 }
注意#!运行/ bin / sh,因此此脚本首先被解释为shell脚本。
起初,我只是尝试了“exec”“/ usr / bin / gawk”“–re-interval”“-f”“$ 0”“$ @”,但awk将其视为命令并打印输出的每一行无条件。这就是为什么我放入arbitrary_long_name == 0 – 它应该一直失败。你可以用一些乱码替换它。基本上,我正在寻找一个假条件在awk,不会不利地影响shell脚本。
在shell脚本中,arbitrary_long_name == 0定义一个名为arbitrary_long_name的变量,并将其设置为等于0。