zoukankan      html  css  js  c++  java
  • awk 调用 shell 命令,并传递参数

    shell 向awk传递命令,这样使用即可: awk -v  ...  但反过来呢?awk调用外部命令,同时也传参呢? 

    awk 中使用的 shell 命令,有 2 种方法:

    一。使用所以 system()

    awk 程序中我们可以使用 system() 函数去调用 shell 命令
    如:awk 'BEGIN{system("echo abc")}' file
    echo abc 就会做为 “命令行”,由 shell 来执行,所以我们会得到以下结果:


    root@ubuntu:~# awk 'BEGIN{system("echo abc")}'
    abc
    root@ubuntu:~#


    root@ubuntu:~# awk 'BEGIN{v1="echo";v2="abc";system(v1" "v2)}'
    abc
    root@ubuntu:~#


    root@ubuntu:~# awk 'BEGIN{v1="echo";v2="abc";system(v1 v2)}'
    /bin/sh: echoabc: command not found
    root@ubuntu:~#


    root@ubuntu:~# awk 'BEGIN{v1=echo;v2=abc;system(v1" "v2)}'
    root@ubuntu:~#

    从上面的例子,我们简单的分析一下 awk 是怎样调用 system 的:
    如果 system()括号里面的参数没有加上双引号的话,awk 认为它是一个变量,它会从 awk 的变量里面把它们先置换为常量,然后再回传给 shell

    如果 system()括号里面的参数有加上双引号的话,那么 awk 就直接把引号里面的内容回传给 shell,作为 shell 的 “命令行”



    二。使用 print cmd | “/bin/bash”

    root@ubuntu:~# awk 'BEGIN{print"echo","abc"|"/bin/bash"}'
    abc
    root@ubuntu:~#


    root@ubuntu:~# awk 'BEGIN{print"echo","abc",";","echo","123"|"/bin/bash"}'
    abc
    123
    root@ubuntu:~#


    三。总结

    无论使用 system()还是 print cmd | “/bin/bash”
    awk 都是新开一个 shell,在相应的 cmdline 参数送回给 shell,所以要注意当前 shell 变量与新开 shell 变量问题

    1.1
    root@ubuntu:~# abc=12345567890
    root@ubuntu:~# awk 'BEGIN{system("echo $abc")}'

    root@ubuntu:~#


    1.2
    root@ubuntu:~# export abc=12345567890
    root@ubuntu:~# awk 'BEGIN{system("echo $abc")}'
    12345567890
    root@ubuntu:~#

    2.1
    root@ubuntu:~# abc=1234567890
    root@ubuntu:~# awk 'BEGIN{print"echo","$abc"|"/bin/bash"}'

    root@ubuntu:~#


    2.2
    root@ubuntu:~# export abc=1234567890
    root@ubuntu:~# awk 'BEGIN{print"echo","$abc"|"/bin/bash"}'
    1234567890
    root@ubuntu:~#


    以上例子,没有 export 的话,那些变量都是只存在于当前 shell 变量中,所以都是 echo 不出来的 ,
    而使用了 export 的都是环境变量,所以 awk 调用新的 shell 时候,可以 echo 出来。

  • 相关阅读:
    静态化之优化
    SEO小技巧
    apache 工具和简单优化
    apache rewrite机制
    nginx php win平台配置
    mvc 简单模型
    php无限分类三种方式
    【转】sqlserver查询数据库中有多少个表
    【转】sqlserver数据库之间的表的复制
    SET ANSI_NULLS (TransactSQL)
  • 原文地址:https://www.cnblogs.com/dahu-daqing/p/9681373.html
Copyright © 2011-2022 走看看