SHELL中的变量

SHELL中的变量

 

         运行SHELL脚本中的单个命令自然有用,但这有其自身的限制。通常你会需要在SHELL命令使用其他数据来处理信息。这可以通过变量来实现。变量允许你临时性地将信息存储在SHELL脚本中,以便和脚本中的其他命令一起使用。

1 环境变量                                               

SHELL维护着一组环境变量,用了记录特点的系统信息。比如系统的名称、登录到系统上的用户名、用户的默认家目录以及SHELL查找程序的搜索路径。可以用set命令来显示一份完整的当前环境变量。

[root@local data]# set |head -30

ABRT_DEBUG_LOG=/dev/null

BASH=/bin/bash

BASHOPTS=checkwinsize:cmdhist:expand_aliases:extglob:extquote:force_fignore:histappend:interactive_comments:login_shell:progcomp:promptvars:sourcepath

BASH_ALIASES=()

BASH_ARGC=()

BASH_ARGV=()

BASH_CMDS=()

BASH_COMPLETION_COMPAT_DIR=/etc/bash_completion.d

[. . . ]

在脚本中,你可以在环境变量名称前加上美元符 $ 来使用这些环境变量。

例如:[root@local data]# echo $HOME

                             /root

2 用户变量                                               

           处理环境变量,SHELL脚本中还允许在脚本中定义和使用自己的变量。定义变量允许临时存储数据并在整个脚本中使用,从而使SHELL脚本看起来更像一个真正的程序。

           用户变量定义规则:可以用字母、数字、下划线组成的文本字符串。长度不超过20个。用户变量区分大小写。

           使用等号将赋值给用户变量。注意:在变量、等号和值之间不能出现空格。

例如:var1=10MYNAME=xiaoming

           1SHELL会自动决定变量值得数据类型。在脚本的整个生命周期中,SHELL 脚本中定义的变量会一直保持着它们的值,但在SHELL结束时会被删除。

           2)变量每次被引用时,都会输出当前赋给它的值。引用一个变量是需要使用美元符”$”,二引用变量来对其进行赋值时则不要使用美元符。

3 只读变量                                               

           只能声明,但是不能修改和删除。

声明只读变量:

                    readonly
      name

                      declare  -r    name

查看只读变量:      readonly   -p

4 位置变量                                               

        在脚本代码中调用命令行传递给脚本的参数

$1$2……:对应第12….个参数,shift[n] 换位置

$0:脚本本身

$*:传递给脚本的所有参数,全部参数合为一个字符串

$@:传递给脚本的所有参数,每个参数为独立的字符串

$#:传递给脚本的参数的个数

注意:$@$* 只有在被双括号扩起来的时候才有差异

set – – 清空所有位置变量

5 命令替换                                               

           SHELL脚本中最有用的特性之一就是可以从命令输出中提取信息,并将其值赋给变量。把输出赋给变量之后,就可以随意在脚本中使用了。

           有两种方法可以将命令输出赋给变量:

(1)       反引号 ( ` )

(2)       $( ) 格式。

例如: testing=`date`

  或者testing=$(date)

在脚本通过命令替换获得当前日期并用来生成唯一文件名。

#!/bin/bash

#

today=$( date +%Y-%m-%d-%H:%M:%S)

ls /root/123 
al  >log.$today

 

原创文章,作者:linux is not unix,如若转载,请注明出处:http://www.178linux.com/73455

(0)
linux is not unixlinux is not unix
上一篇 2017-04-16 19:40
下一篇 2017-04-16 20:21

相关推荐

  • 用户和组管理类命令的使用

    1.列出当前系统所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示以此即可; who | cut -d' ' -f1 | sort | uniq 2.取出最后登录到当前系统的用户的相关信息; who | head&nb…

    Linux干货 2016-11-21
  • ansible实践

    本偏文章以上图拓扑部署 首先准备了6台为centos7的主机(确保selinux和iptables不会成阻碍!关闭他们) 我们先来安装ansible吧! 配置EPEL源过后使用 yum -y install ansible  !!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 出师不利啊,安装ansible就失败了。!!!!!! 看了一下…

    Linux干货 2017-01-27
  • Linux的发展史和Linux的终端类型

    Linux的发展史和Linux的终端类型 前言:    随着时代的发展,Linux所占的市场份额越来越大,目前几乎百分之九十的服务器市场都被Linux占据。接下来我们来聊聊Linux的发展史。 简单的说:Linux操作系统是1998年的8月芬兰的一个叫Linus Torvalds的大学生写出来的一个类minix的系统。 具体分析: Lin…

    Linux干货 2016-10-17
  • 马哥教育网络班21期+第14周课程练习

    iptables关键点 表:filter(过滤,防火墙);nat(网络地址转换);mangle(拆解报文,做出修改,封装报文);raw(关闭nat表启用的链接追踪机制);上述是根据功能来区分的,写规则要明白要实现的功能 链:PREROUTING,INPUT,FORWARD,OUTPUT,POSTROUTING 数据流向:流入PREROUTING–…

    Linux干货 2016-08-26
  • Linux基础知识(四)-正则表达式grep,egrep

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 2、编辑/etc/group文件,添加组hadoop。 3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home/hadoop。 4、复制/etc/sk…

    Linux干货 2016-10-17
  • iptables介绍和使用

    iptables/netfilter:    Packets Filter Firewall:          包过滤型防火墙:  Firewall:隔离工具,工作于主机或网络的边缘处,对经由的报文根据预先定义的规则(识别标准)进行检测,对于能够被规则匹配到的报文实行…

    Linux干货 2017-04-29