shell脚本的一点补充

脚本内容补充


数组

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

数组名和索引

索引:编号从0开始,属于数值索引
注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引,bash4.0版本之后开始支持。bash的数组支持稀疏格式(索引不连续)

数组的使用

声明数组:

declare -a ARRAY_NAME

declare -A ARRAY_NAME: 关联数组

数组元素的赋值:

(1) 一次只赋值一个元素;

  • ARRAY_NAME[INDEX]=VALUE

  • weekdays[0]="Sunday"

  • weekdays[4]="Thursday"

(2) 一次赋值全部元素:

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

(3) 只赋值特定元素:

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

(4) 交互式数组值对赋值

  • read -a ARRAY

(5) 关联数组的赋值
必须先定义,然后赋值

  • declare -A shu_zu

  • shu_zu=([a]="sadas" [b]=22 [w2]=w [2]=2)

    [root@qzx ~]# declare -A shu_zu
     [root@qzx ~]# shu_zu=([2]=4 [a]="ni shi shui " [b]=22 [w1w]="ww s")

    [root@qzx ~]# echo ${shu_zu[w1w]}
     ww s
     [root@qzx ~]# echo ${shu_zu[b]}
     22
     [root@qzx ~]# echo ${shu_zu[*]}
     ww s ni shi shui 22 4

引用数组

引用数组元素:${ARRAY_NAME[0]}
注意:省略[0]表示引用下标为0的元素
数组的长度(数组中元素的个数)
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}

示例:生成10个随机数保存于数组中,并找出其最大值和最小值
#!/bin/bash
declare -a rand
declare -i max=0
for i in {0..9}; do
rand[$i]=$RANDOM
echo ${rand[$i]}
[ ${rand[$i]} -gt $max ] && max=${rand[$i]}
done
echo "Max: $max"

编写脚本,定义一个数组,数组中的元素是/var/log目录下所有以.log结尾的文件
;要统计其下标为偶数的文件中的行数之和
#!/bin/bash
#
declare -a files
files=(/var/log/*.log)
declare -i lines=0
for i in $(seq 0 $[${#files[*]}-1]); do
if [ $[$i%2] -eq 0 ];then
let lines+=$(wc -l ${files[$i]} | cut -d' ' -f1) 
fi
done
echo "Lines: $lines."

作业练习:
1.输入若干个数值存入数组中,采用冒泡算法进行升序或降序排序

#!/bin/bash
#qzx
#
declare -a paixu
print()
{
echo ${paixu[*]}
}
for ((i=0;i<10;i++))
do 
    let paixu[$i]=$RANDOM%100
done
echo "刚赋值的"
print
echo "==============================================="
for ((i=0;i<9;i++))
do 
    #let c=9-i
    for((j=0;j<9-i;j++))
    do    
    #    
        if [[ ${paixu[$j]} -lt  ${paixu[$j+1]} ]]    
        then     
            a=${paixu[$j]}
            paixu[$j]=${paixu[$j+1]}
            paixu[$j+1]=$a

        fi
    done
done
echo "倒排序的"
print
echo "=============================================="
for ((i=0;i<5;i++))
do
     a=${paixu[$i]}
         paixu[$i]=${paixu[9-$i]}
         paixu[9-$i]=$a
done

echo "正序排列" 
print

数组数据处理

引用数组中的元素:

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

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

    • offset: 要跳过的元素个数

    • number: 要取出的元素个数

    [root@qzx ~]# read -a qiuzx
    2 34 5 77 44 83 2
    [root@qzx ~]# echo ${qiuzx[@]:2:4}
    5 77 44 83

取偏移量之后的所有元素
${ARRAY[@]:offset}

向数组中追加元素:
ARRAY[${#ARRAY[*]}]=“在原有数据上追加一个的值”

删除数组中的某元素:导致稀疏格式
unset ARRAY[INDEX]

关联数组:
declare -A ARRAY_NAME
ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘…)

字符串处理

字符串切片:这里的offset,number,-lengh均为数字

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

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

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

  • ${var:    -lengh}:取字符串的最右侧几个字符:
    注意:冒号后必须有一空白字符

  • ${var : offset :  -lengh}:取字符串从offset之后的(不包括offset这个字符)到从右侧数第lengh个字符之前的字符

      [root@qzx ~]# a=00123456789
      [root@qzx ~]# echo ${#a}
      11
      [root@qzx ~]# echo ${a:3: -4}
      2345
      [root@qzx ~]# echo ${a:3}
      23456789
      [root@qzx ~]# echo ${a:3:4}
      2345

基于模式取子串:

  • ${var#*word}:其中word可以是指定的任意字符
    功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次出现word字符之间的所有字符

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

    file="/var/log/messages"
    ${file##*/}: messages

    [root@qzx ~]# echo ${a#*0}
    0123456789
    [root@qzx ~]# echo ${a##*0}
    123456789

  • ${var%word*}:其中word可以是指定的任意字符;
    功能:自右而左,查找var变量所存储的字符串中,第一次出现的word, 删除字符串最后一个字符向左至第一次出现word字符之间的所有字符;

    file="/var/log/messages"
    ${file%/*}: /var/log

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

    示例:url=http://www.magedu.com:80
    ${url##:} 80
    ${url%%:
    } http\

字符串处理

查找替换:

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

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

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

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

查找并删除:
${var/pattern}:查找var所表示的字符串中,删除第一次被pattern所匹配到的字符串
${var//pattern}:所有
${var/#pattern}:行首
${var/%pattern}:行尾

    [root@qzx ~]# a=000111222111222000111222000222

    [root@qzx ~]# echo ${a/000}
    111222111222000111222000222

    [root@qzx ~]# echo ${a//000}
    111222111222111222222

    [root@qzx ~]# echo ${a/%222}
    000111222111222000111222000

    [root@qzx ~]# echo ${a/#000}
    111222111222000111222000222

字符大小写转换:

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

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

变量赋值

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

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

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

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

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

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

declare [选项] 变量名

-r 将变量设置为只读属性
-i 将变量定义为整型数
-a 将变量定义为数组
-f 显示此脚本前定义过的所有函数名及其内容
-F 仅显示此脚本前定义过的所有函数名
-x 将变量声明为环境变量
-l  将变量值转为小写字母
-u  将变量值转为大写字母

间接变量引用

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

  • variable1=variable2

  • variable2=value

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

间接变量引用实例:
bash Shell提供了两种格式实现间接变量引用
eval tempvar=\$$variable1
tempvar=${!variable1}

示例:

    [root@server ~]# N=NAME
    [root@server ~]# NAME=wangxiaochun
    [root@server ~]# N1=${!N}
    [root@server ~]# echo $N1
    wangxiaochun
    [root@server ~]# eval N2=\$$A
    [root@server ~]# echo $2
    wangxiaochun

这种是间接中的变量引用,是动态引用的!

创建临时文件

mktemp命令:创建的临时文件可避免冲突
语法:mktemp [OPTION]… [TEMPLATE]
TEMPLATE: filename.XXX
X至少要出现三个

选项:
-d: 创建临时目录
–tmpdir=/DIR:指明临时文件所存放的目录位置

实例:

 #mktemp --tmpdir=/testdir test.XXXXXXmktemp

安装复制文件

install命令:

install [OPTION]… [-T] SOURCE DEST 单文件
install [OPTION]… SOURCE… DIRECTORY
install [OPTION]… -t DIRECTORY SOURCE…
install [OPTION]… -d DIRECTORY…创建空目录(支持递归创建)

在前两种格式中,会将<来源>复制至<目的地>或将多个<来源>文件复制至已存在的<目录>,同时设定权限模式及所有者/所属组。在第三种格式中,会创建所有指定的目录及它们的主目录。

选项:
-m MODE,自行设定权限模式 (像chmod),而不是rwxr-xr-x,默认755
-o OWNER
-g GROUP

bash如何展开命令行

优先级从高到低

  1. 把命令行分成单个命令词

  2. 展开别名

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

  4. 展开波浪符声明(~)

  5. 命令替换$() 和 “)

  6. 再次把命令行分成命令词

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

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

  9. 运行命令

防止扩展

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

$ echo Your cost: \$5.00
Your cost: $5.00

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

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

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

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

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

bash的配置文件

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

全局配置:

/etc/profile
/etc/profile.d/*.sh
/etc/bashrc

个人配置:

~/.bash_profile
~/.bashrc

shell登录两种方式

交互式登录:

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

(2)使用“su – UserName” 切换的用户

执行顺序:
/etc/profile –> /etc/profile.d/*.sh –> ~/.bash_profile –> ~/.bashrc –> /etc/bashrc

非交互式登录:

(1)su UserName
(2)图形界面下打开的终端
(3)执行脚本

执行顺序:
~/.bashrc –> /etc/bashrc –> /etc/profile.d/*.sh

Profile类

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

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

  • 个人:~/.bash_profile

功用:
(1) 用于定义环境变量
(2) 运行命令或脚本

Bashrc类

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

  • 全局:/etc/bashrc

  • 个人:~/.bashrc

功用:
(1) 定义命令别名和函数
(2) 定义本地变量

修改profile和bashrc文件后需生效方法

两种方法:
1重新启动shell进程
2 . 或source

例:
. ~/.bashrc

Bash 退出任务

保存在~/.bash_logout文件中(用户)
在退出登录shell时运行
用于
• 创建自动备份
• 清除临时文件

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

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

相关推荐

  • N22-第二周作业-对Linux的基础操作命令的理解及用法示例

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 Linux上文件管理类命令常用的有:pwd、ls、cd、cp、touch、mv、rm、rmdir   1)pwd:显示当前工作目录     2)ls:列出指定目录下的内容    常用的选项有:   -a:列出目录中的所有文…

    Linux干货 2016-08-22
  • 编写脚本

        1、  编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPV4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小。                      …

    2017-04-13
  • Linux基础知识(四)

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限 [root@bogon ~]# cp -r /etc/skel/ /home/tuser1 [root@bogon ~]# chmod -R 700 /home/tuser1 2、编辑/etc/group文件,添加组hadoo…

    Linux干货 2016-10-17
  • inode、软硬链接区分、ln命令

    inode、软硬链接区分、ln命令 一、inode inode记录的是文件的属性及文件实际放在那块数据块中的。inode包含以下数据: 1. 该文件的可被访问的权限(read/write/excute) 2. 该文件的属主、属组(owner、group) 3. 该文件的大小 4. 该文件创建或者状态改变的时间(Ctim…

    Linux干货 2016-08-02
  • Linux-raid的工作原理与管理

    本章内容:        1、RAID详细描述        2、mdadm 工具        3、创建raid        4、磁盘阵列的管理 RAID描述:     &nb…

    2017-06-24
  • mariadb之再次演练

    架构图如下: 1.按照架构图所示,准备机器,做好时间同步,主机名解析 192.168.42.150 node1 [proxySQL keepalived]192.168.42.151 node2 [proxySQL keepalived]192.168.42.152 node3 [mysql-master wha]192.168.42.153 node4 […

    Linux干货 2016-03-06