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
下一篇 2017-04-16

相关推荐

  • 权限管理

    权限管理包括普通权限、特殊权限、默认权限、ACL权限。 这些权限都是针对u(owner)、g(group)、o(other)三类定义的。 设置权限时文件和目录不同(此处把文件和目录分开,一般说文件就包含目录(linux思想:一切皆文件))如下图所示, 分别用两个用户分别创建了一个目录一个文件,可以看到同是目录的liutest和test的权限不同,它俩同为目录…

    Linux干货 2017-07-30
  • awk用法三

      6、结构化控制语句     6.1 if语句       格式:if(条件) {body} else {else body}         实例1:判断/etc/passwd文件中的UID如果大于500则显示为“common user”,否则显…

    Linux干货 2016-02-14
  • 文本处理工具

    文本处理工具 文件内容:less和 cat,more文件截取:head和tail文本内容处理:tr按列抽取:cut按关键字抽取:grep 文件查看命令:cat, tac,rev cat  复制标准输入到当前输出 语法:cat [OPTION]… [FILE]…选项: -E: 显示行结束符$ -n: 对显示出的每一行进行编号 -A:显示所有…

    Linux干货 2016-08-07
  • Ansible (playbook)

    一、YAML 1.1 YAML介绍 YAML是一个可读性高的用来表达资料序列的格式。YAML参考了其他多种语言,包括:XML、C语言、Python、Perl以及电子邮件格式RFC2822等。Clark Evans在2001年在首次发表了这种语言,另外Ingy döt Net与Oren Ben-Kiki也是这语言的共同设计者。 YAML Ain’t Marku…

    Linux干货 2017-11-01
  • 第四周练习

    1、复制/etc/skel目录为/home/tuser1, 要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 cp -r /etc/skel /home/tuser1 chmod -R 700 /home/tuser1 2、编辑/etc/group文件,添加组hadoop。 vi /etc/group hadoop:x:2017 …

    Linux干货 2017-08-04