zoukankan      html  css  js  c++  java
  • shell eval命令使用

    eval命令将会首先扫描命令行进行所有的置换,然后再执行该命令。
    该命令适用于那些一次扫描无法实现其功能的变量。该命令对变量进行两次扫描。
    这些需要进行两次扫描的变量有时被称为复杂变量。不过这些变量本身并不复杂。
    eval命令也可以用于回显简单变量,不一定是复杂变量。

    1.eval命令也可以用于回显简单变量,不一定是复杂变量
    例如: 

    [neau@mail ~]$ NAME=VALUEBANK
    [neau@mail ~]$ eval echo $NAME
    VALUEBANK
    [neau@mail ~]$ echo $NAME
    VALUEBANK

    2.执行含有字符串的命令
    首先我们首先创建一个名为test的小文件,在这个小文件中含有一些文本。接着,将cat test赋给变量myfile,现在我们e c h o该变量,看看是否能够执行上述命令。
    [neau@mail ~]$ vi test
    [neau@mail ~]$ cat test
    Hello World!!!
    I am a chinese Boy!
    将cat testf赋给变量myfile
    [neau@mail ~]$ myfile="cat test"
    如果我们echo该变量,我们将无法列出test文件中的内容。
    [neau@mail ~]$ echo $myfile
    cat test
    让我们来试一下eval命令,记住eval命令将会对该变量进行两次扫瞄。
    [neau@mail ~]$ eval $myfile
    Hello World!!!
    I am a chinese Boy!
    从上面的结果可以看出,使用eval命令不但可以置换该变量,还能够执行相应的命令。第一次扫描进行了变量置换,
    第二次扫描执行了该字符串中所包含的命令cat test。

    3.命令还可以用来显示出传递给脚本的最后一个参数
    [neau@mail ~]$ cat test1
    #!/bin/bash
    echo "Total of the arguments passed $#"
    echo "The process Id is $$"
    echo "Last argument is "$(eval echo $$#)""
    [neau@mail ~]$ ./test1 value bank test last
    Total of the arguments passed 4
    The process Id is 21545
    Last argument is last
    在上面的脚本中, eval命令首先把$$#解析为当前shell的参数个数,然后在第二次扫描时得出最后一个参数。

    4.给每个值一个变量名
    可以给一个值一个变量名。下面我对此做些解释,假定有一个名为test2的文件:
    [neau@mail ~]$ cat test2
    CCTV 5
    CHANGEL SPORTS
    LIKE YES
    你希望该文件中的第一列成为变量名,第二列成为该变量的值,这样就可以:
    [neau@mail ~]$ cat test2
    COMMANY TQ
    LANGUE ENGLISH
    LIKE YES
    [neau@mail ~]$ cat test3
    #!/bin/bash
    while read NAME VALUE
    do
    eval "${NAME}=${VALUE}"
    done  
    echo "$COMMANY $LANGUE $LIKE"
    [neau@mail ~]$ ./test3
    TQ ENGLISH YES
  • 相关阅读:
    php 转化整型需要注意的地方
    生成6位随机数
    php://input
    ios常见问题 经验之谈
    ios 从前台返回到回台 从后台返回到前台 或者 支付宝支付订单后 对界面进行操作
    ios根据文本自适应 然后 搭建类似如下效果
    iosTableView 局部全部刷新以及删除编辑操作
    ios打开系统自带APP
    iOS通过URL Scheme启动app(收集了常用的app的URL Scheme)
    ios UIApplocation 中APP启动方式
  • 原文地址:https://www.cnblogs.com/xialiaoliao0911/p/7523980.html
Copyright © 2011-2022 走看看