加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

shell – 如何使用多个参数与shebang(即#!)?

发布时间:2020-12-15 16:48:42 所属栏目:安全 来源:网络整理
导读:我想使用shebang执行一个 gawk脚本与–re-interval。 “天真”的方法 #!/usr/bin/gawk --re-interval -f... awk script goes here 不工作,因为gawk调用第一个参数“–re-interval -f”(不分割在空格周围),它不明白。有没有解决方法? 当然,你可以不直接调
我想使用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。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读