shell脚本编程3

补充,shift使用方法

root@localhost wang]# cat jiaoben1.sh 
#!/bin/bash
echo "$1"
echo "$*"
shift
echo "$1"
echo "$*"
shift
echo "$1"
echo "$*"
shift 2
echo "$1"
echo "$*"
[root@localhost wang]# bash jioaben1.sh a b c d e f g 
a
a b c d e f g
b
b c d e f g
c
c d e f g
e
e f g

匿名函数{}

例:flase || { echo "xxx";exit }

十三、数组

    变量:存储单个元素的内存空间

    数组:存储多个元素的连续的内存空间,相当于多个变量的集合。

    数组名和索引

        索引:编号从0开始,属于数值索引

        注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引, bash4.0版本之后开始支持。

        bash的数组支持稀疏格式(索引不连续)

    定义数组

    声明数组:

        declare -a ARRAY_NAME

        declare -A ARRAY_NAME: 关联数组

        注:先声明,在使用。

    数组元素的赋值:

        一次只赋值一个元素;

            ARRAY_NAME[INDEX]=VALUE

[root@localhost wang]# tom[1]=a
[root@localhost wang]# tom[2]=b
[root@localhost wang]# tom[3]=c
[root@localhost wang]# echo ${tom[*]}
a b c
[root@localhost wang]# echo ${tom[1]}
a
[root@localhost wang]# echo ${tom[2]}
b

        一次赋值全部元素:

            ARRAY_NAME=("VAL1" "VAL2" "VAL3" …)

[root@localhost wang]# jay=(q w e r d f)
[root@localhost wang]# echo ${jay[*]}
q w e r d f
[root@localhost wang]# echo ${jay}
q
[root@localhost wang]# echo ${jay[1]}
w
[root@localhost wang]# echo ${jay[2]}
e

        只赋值特定元素:

            ARRAY_NAME=([0]="VAL1" [3]="VAL2" …)

[root@localhost wang]# ban=([1]=one [2]=two [3]=three)
[root@localhost wang]# echo ${ban[*]}
one two three
[root@localhost wang]# echo ${ban[1]}
one
[root@localhost wang]# echo ${ban[2]}
two

        交互式数组值对赋值

            read -a ARRAY

    引用数组

    引用数组元素: ${ARRAY_NAME[INDEX]}

        注意:省略[INDEX]表示引用下标为0的元素

    数组的长度(数组中元素的个数):

        ${#ARRAY_NAME[*]}

        ${#ARRAY_NAME[@]}

[root@localhost wang]# echo ${jan[*]}
a bc def ghij klmno pqrst uvwxyz
[root@localhost wang]# echo ${#jan[*]}
7
[root@localhost wang]# echo ${jan}
a
[root@localhost wang]# echo ${#jan}
1
[root@localhost wang]# echo ${jan[2]}
def
[root@localhost wang]# echo ${#jan[2]}
3

    示例:生成10个随机数保存于数组中,并找出其最大值和最小值

[root@localhost sh.log]# cat declareminmax.sh 
#!/bin/bash
#author:DYW
#生成10个随机数,取最大最小值。
declare -a zu
declare -i min
declare -i max
for a in {0..9};do
	zu[$a]=$RANDOM
	[ $a -eq 0 ]&& { min=${zu[$a]};max=${zu[$a]}; }
	[ $min -gt ${zu[$a]} ] && min=${zu[$a]}
	[ $max -lt ${zu[$a]} ] && max=${zu[$a]}
done
echo "all number are ${zu[*]}"
echo "max:$max min:$min"
[root@localhost sh.log]# bash declareminmax.sh 
all number are 12445 5069 3252 2204 16619 2817 9614 7954 25200 17136
max:25200 min:2204

    数组数据处理

    引用数组中的元素:

        所有元素: ${ARRAY[@]}, ${ARRAY[*]}

        数组切片: ${ARRAY[@]:offset:number}

            offset: 要跳过的元素个数

            number: 要取出的元素个数

            取偏移量之后的所有元素

                {ARRAY[@]:offset}

[root@localhost wang]# echo ${jan[*]}
a bc def ghij klmno pqrst uvwxyz
[root@localhost wang]# echo ${jan[*]:2:3}
def ghij klmno
[root@localhost wang]# echo ${jan[*]:2}
def ghij klmno pqrst uvwxyz

    向数组中追加元素:

        ARRAY[${#ARRAY[*]}]

    删除数组中的某元素:导致稀疏格式

        unset ARRAY[INDEX]

    关联数组:

        declare -A ARRAY_NAME

        ARRAY_NAME=([idx_name1]=('val1' [idx_name2]='val2‘…)

十四、字符串处理

bash的字符串处理工具:

字符串切片:

${#var}:返回字符串变量var的长度

${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 到 ${#var}-1 之间

${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分

${var: -lengh}:取字符串的最右侧几个字符:

注意:冒号后必须有一空白字符

[root@localhost ~]# echo $var
abcdefghijklmnopqrstuvwxyz
[root@localhost ~]# echo ${var:3}
defghijklmnopqrstuvwxyz
[root@localhost ~]# echo ${var:3:5}
defgh
[root@localhost ~]# echo ${var: -3}
xyz
[root@localhost ~]# echo ${var:3: -3}
defghijklmnopqrstuvw
[root@localhost ~]# echo ${var:3: -3}

    基于模式取子串:

        ${var#*word}:其中word可以是指定的任意字符

            功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次出现word字符之间的所有字符

        ${var##*word}:同上,不同的是,删除的是字符串开头至最后一次由word指定的字符之间的所有内容

            file="/var/log/messages"

            ${file##*/}: messages

        ${var%word*}:其中word可以是指定的任意字符;

            功能:自右而左,查找var变量所存储的字符串中,第一次出现的word, 删除字符串最后一个字符向左至第一次出现word字符之间的所有字符;

                file="/var/log/messages"

                ${file%/*}: /var/log

        ${var%%word*}:同上,只不过删除字符串最右侧的字符向左至最后一次出现word字符之间的所有字符;

[root@localhost ~]# echo $var
root:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var#*root}
:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var##*root}
:/bin/bash
[root@localhost ~]# echo ${var%:*}
root:x:0:0:root,,62985600:/root
[root@localhost ~]# echo ${var%%:*}
root

    查找替换:

        ${var/pattern/substi}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substi替换之

        ${var//pattern/substi}: 查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substi替换之

        ${var/#pattern/substi}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substi替换之

        ${var/%pattern/substi}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substi替换之

[root@localhost ~]# echo $var
root:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var/root/laowang}
laowang:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var//root/laowang}
laowang:x:0:0:laowang,,62985600:/laowang:/bin/bash
[root@localhost ~]# echo ${var/#root/laowang}
laowang:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var/%bash/laowang}
root:x:0:0:root,,62985600:/root:/bin/laowang

    查找并删除:

        ${var/pattern}:查找var所表示的字符串中,删除第一次被pattern所匹配到的字符串

        ${var//pattern}:所有

        ${var/#pattern}:首行

        ${var/%pattern}:行尾

    字符大小写转换:

        ${var^^}:把var中的所有小写字母转换为大写

        ${var,,}:把var中的所有大写字母转换为小写

    变量赋值

        ${var:-value}:如果var为空或未设置,那么返回value;否则,则返回var的值

[root@localhost ~]# var=laowang
[root@localhost ~]# echo ${var:-mage}
laowang
[root@localhost ~]# unset var
[root@localhost ~]# echo ${var:-mage}
mage

        ${var:+value}:如果var不空,则返回value

[root@localhost ~]# var=laowang
[root@localhost ~]# echo ${var:+mage}
mage
[root@localhost ~]# unset var
[root@localhost ~]# echo ${var:+mage}

        ${var:=value}:如果var为空或未设置,那么返回value,并将value赋值给var;否则,则返回var的值

[root@localhost ~]# echo ${var:=mage}
laowang
[root@localhost ~]# unset var
[root@localhost ~]# echo ${var:=mage}
mage

        ${var:?error_info}:如果var为空或未设置,那么返回error_info;否则,则返回var的值为脚本程序使用配置文件,实现变量赋值

[root@localhost ~]# var=laowang
[root@localhost ~]# echo ${var:?mage}
laowang
[root@localhost ~]# unset var
[root@localhost ~]# echo ${var:?var is empty}
-bash: var: var is empty

    定义文本文件,每行定义“ name=value”

    在脚本中source此文件即可

    高级变量用法-有类型变量

    Shell变量一般是无类型的,但是bash Shell提供了declare和typeset两个命令用于指定变量的类型,两个命令是完全等价的

    declare [选项] 变量名

        -r 将变量设置为只读属性

        -i 将变量定义为整型数

        -a 将变量定义为数组

        -A 将变量定义为关联数组

        -f 显示此脚本前定义过的所有函数名及其内容

        -F 仅显示此脚本前定义过的所有函数名

        -x 将变量声明为环境变量

        -l 将变量值转为小写字母

        -u 将变量值转为大写字母

    间接变量引用

    如果第一个变量的值是第二个变量的名字,从第一个变量引用第二个变量的值就称为间接变量引用

    variable1=variable2

    variable2=value

    variable1的值是variable2,而variable2又是变量名,variable2的值为value,间接变量引用是指通过variable1获得变量值value的行为

    bash Shell提供了两种格式实现间接变量引用

    eval tempvar=\$$variable1

[root@localhost ~]# v1=v2
[root@localhost ~]# v2=wang
[root@localhost ~]# ecal v3=\$$v1
-bash: ecal: command not found
[root@localhost ~]# eval v3=\$$v1
[root@localhost ~]# echo $v3
wang

    tempvar=${!variable1}

[root@localhost ~]# v1=v2
[root@localhost ~]# v2=wang
[root@localhost ~]# v3=${!v1}
[root@localhost ~]# echo $v3
wang

eval命令

    eval命令将会首先扫描命令行进行所有的置换,然后再执行该命令。该命令适用于那些一次扫描无法实现其功能的变量。该命令对变量进行两次扫描。

[root@localhost ~]# cmd=pwd
[root@localhost ~]# echo $cmd
pwd
[root@localhost ~]# eval $cmd
/root

创建临时文件

    mktemp命令:创建的临时文件可避免冲突

    mktemp [OPTION]… [TEMPLATE]

        TEMPLATE: filename.XXX

        X至少要出现三个

    OPTION:

        -d: 创建临时目录

        -p dir或–tmpdir=/DIR:指明临时文件所存放的目录位置

[root@localhost wang]# mktemp file.XXX
file.MCe
[root@localhost wang]# a=`mktemp file.XXX`
[root@localhost wang]# echo $a
file.4P8

    安装复制文件

    install命令:

        install [OPTION]… [-T] SOURCE DEST 单文件

        install [OPTION]… SOURCE… DIRECTORY

        install [OPTION]… -t DIRECTORY SOURCE…

        install [OPTION]… -d DIRECTORY…创建空目录

    选项:

        -m MODE,默认755

        -o OWNER

        -g GROUP

        -d 创建目录

    bash如何展开命令行

        把命令行分成单个命令词

        展开别名

        展开大括号种的声明( {})

        展开波浪符声明( ~)

        命令替换$() 和 “)

        再次把命令行分成命令词

        展开文件通配( *、 ?、 [abc]等等)

        准备I/0重导向( <、 >)

        运行命令

        

    防止扩展

        反斜线( \)会使随后的字符按原意解释

            $ echo Your cost: \$5.00

            Your cost: $5.00

        加引号来防止扩展

            单引号( ’)防止所有扩展

            双引号( ”)也防止所有扩展,但是以下情况例外:

            ↘$(美元符号) - 变量扩展

            ↘`(反引号) - 命令替换

            ↘\(反斜线) - 禁止单个字符扩展

            ↘!(叹号) - 历史命令替换

    bash的配置文件

        按生效范围划分,存在两类:

        全局配置:

            /etc/profile

            /etc/profile.d/*.sh

            /etc/bashrc

        个人配置:

            ~/.bash_profile

            ~/.bashrc

    shell登录两种方式

        交互式登录:

            直接通过终端输入账号密码登录;

            使用“ su – UserName” 切换的用户

        执行顺序:

            /etc/profile –> /etc/profile.d/*.sh –> ~/.bash_profile –> ~/.bashrc –> /etc/bashrc

        非交互式登录:

            su UserName

            图形界面下打开的终端

            执行脚本

        执行顺序:

            ~/.bashrc –> /etc/bashrc –> /etc/profile.d/*.sh

    Profile类

        按功能划分,存在两类:

            profiile类和bashrc类

        profile类:为交互式登录的shell提供配置

            全局: /etc/profile, /etc/profile.d/*.sh

            个人: ~/.bash_profile

            功用:

            用于定义环境变量

            运行命令或脚本

    Bashrc类

        bashrc类:为非交互式和交互式登录的shell提供配置

            全局: /etc/bashrc

            个人: ~/.bashrc

            功用:

                定义命令别名和函数

                定义本地变量

    编辑配置文件生效

        修改profile和bashrc文件后需生效

            两种方法:

                重新启动shell进程

                . 或source

        例:

            . ~/.bashrc

    Bash 退出任务

        保存在~/.bash_logout文件中(用户)

        在退出登录shell时运行

        用于

        创建自动备份

        清除临时文件

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

(0)
DYWDYW
上一篇 2016-08-24
下一篇 2016-08-24

相关推荐

  • linux基础知识

    冯*诺依曼体系 摩尔定律

    2018-03-26
  • Linux部分命令及使用

    Linux部分命令解释及使用 ASCII 信息交换码  GB2312 big5 UTF-8 字符集 乱码问题 生产环境中最常见故障  字符集格式设置不一致 查看系统版本  cat /etc/redhat-release  $() “&nb…

    2017-04-09
  • 8.4日作业

    1、用正则表达式表示IP地址 ifconfig | grep -E -o "(\<([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>\.){3}(\<[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]25[0-5]\>)" 5、用正…

    Linux干货 2016-08-08
  • 22期第五周课堂练习

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; [root@localhost ~]# grep "^[[:space:]]\+" /boot/grub/grub.conf 2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又…

    Linux干货 2016-09-08
  • 运维面试题和答案

    1、简述TCP三次握手四次挥手过程及各过程中客户端和服务器端的状态。 #三次握手 客户端向服务器端发送SYN包,客户端进入SYN_SEND状态 服务器端收到客户端发送的包返回ACK+SYN包,服务器端进入SYN_RECV状态 客户端收到服务器端返回的包再发回ACK包,客户端进入ESTABLISHED状态,服务器端收到包也进入ESTABLISHED状态 客户端…

    Linux干货 2016-06-10
  • linux基本命令的使用

      1>    查看当前终端名:tty 或who am i       查看当前所有登录的终端信息:who       查看当前所有登录的终端的详细信息 w 2> 编辑器    …

    2017-07-15