Bash Shell脚本编程笔记总结(二)

本文接上一部分:Bash Shell脚本编程笔记总结(一)

数组:

连续的多个独立内存空间,每个内存空间相当于一个变量

数组元素:数组名+索引

索引:从0开始编号

声明数组:

declare -a ARRAR_NAME

关联数组:

declare -A ARRAY_NAME

支持稀疏格式:

数组元素的赋值:

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

ARRAY[index]=VALUE

a[0]="hello"

(2) 一次赋值全部元素

ARRAY=("mon" "tue" "wed")

(3) 指定索引进行赋值

ARRAY=([0]="sun" [1]="mon" [5]="fri")

(4) read -a ARRAY

引用数组元素:${ARRAY[index]}

数组的长度:

${#ARRAY[*]}, ${#ARRAY[@]}

练习1:写一个脚本,生成10个随机数,保存至数组rand中;而后显示数组索引为偶数的元素的值;

rand[$i]=$RANDOM

#!/bin/bash
#
for i in {0..9}; do
    rand[$i]=$RANDOM
    [ $[$i%2] -eq 0 ] && echo "$i:${rand[$i]}"
done

练习:写一个脚本:

定义一个数组,数组元素为/var/log目录下,所有以.log结尾的文件的名字;

而后显示其索引为奇数的元素的内容;

#!/bin/bash
declare -a files
files=(/var/log/*.log)
for i in `seq 0 $[${#files[*]}-1]`; do
    [ $[$i%2] -ne 0 ] && echo "$i: ${files[$i]}"
done

从数组中挑选某元素:

${ARRAY[@]:offset:number}

对于:week=(mon tue wed thu fri sat sun)

${week[@]:3:2}结果为:

切片:

offset: 偏移过去的元素的个数;

number: 取出的元素的个数;

${ARRAY[@]:offset}

取出指定偏移量之后的所有元素;

${ARRAY[@]}, ${ARRAY[*]}

取出所有元素;

向数组中追加元素:非稀疏格式

week,

week[${#week[@]}]

从数组中删除元素:

unset ARRAY[index]

关联数组:

可自定义任意字符串当作索引

declare -A week

week=([mon]="Monday" [tue]="Tuesday")

练习:生成10个随机数;排序;

#!/bin/bash
for i in {0..9} ; do
        rand[$i]=$RANDOM
        echo "${rand[$i]}" >> test.txt
done
sort -n test.txt
rm -rf test.txt

字符串操作

返回$string的长度

${#string}

例子:

# mypath="sysconfig/network-scripts/ifcfg-eth"
# echo ${#mypath}
35

在$string中,如果变量名存在且非空,则返回word;否则返回空

${string:+UNSET}

例子:

# unset result
# unset test
# echo result
result
# echo $result
# echo $test
# echo $result
# echo $test
# test="google"
# result=${test:+UNSET}
# echo $test
google
# echo $result
UNSET

当$string未定义或者为空时;返回word内容,否则返回变量的值:

${string:-word}

例子:

# result=${test:-UNSET}
# echo $result
UNSET
# echo $test
# test="google"
# result=${test:-UNSET}
# echo $result         
google

当$string变量未定义时,将-后的word的内容赋值个变量string

$(string-word}

例子:

# result=${test-google}
# echo $test
# echo $result
google

生产环境应用:

/etc/init.d/httpd

/etc/init.d/crond

对变量的路径进行操作,最好先判断变量是否为空,特别是删除操作

path=/server/backup
find ${path-/tmp/} -name *.tar.gz -type f |xargs rm -rf
注意:下面的意义,如果path变量不存在了,那么直接就把/tmp这个路径赋值给path,不会去删除根目录了
#rm -rf ${path-/tmp/}

当$string变量有内容时;就返回变量值,否则就会给变量赋值word的内容。

${string:=word}

例子:

# unset result
# echo $result
# unset test
# echo $test
# result=${test:=UNSET}
# echo $result
UNSET
# echo $test
UNSET

在$string中,取字符串最后几个字符

${string:  -lenth}

a="world" , ${a:  -2} , ld

例子:

# mypath="sysconfig/network-scripts/ifcfg-eth"
# echo ${mypath: -3}
eth
注意:冒号后面有空格

在$string中,如变量名存在且非空,则返回变量值;否则显示变量名:message,并退出当前命令或者脚本。

$(string:? "message"}

例子:

# result=${test:? "not defined"}
# echo $result
google
# unset result
# unset test
# result=${test:? "not defined"}
-bash: test:  not defined

在$string中,从位置$offset之后提取字串

${string:offset}

例子:

# test="google"                 
# result=${test:2}
# echo $result
ogle

在$string中,从位置$offset之后提取长度为$length的字串

${string:offset:lenth}

string:是一个字符类型变量

a="world" , ${a:2:2} , rl

例子:

# mypath="sysconfig/network-scripts/ifcfg-eth"
# echo ${mypath:3:4}
conf

基于模式取子串

${string#*word}

其中word可以是指定的任意字符,自左而右,查找sting变量所存储字符中,第一次出现的word,删除字符开头直至第一次word出现处之间的所有字符

例子:

# mypath="sysconfig/network-scripts/ifcfg-eth"
# echo ${mypath#*/}
network-scripts/ifcfg-eth

${string##*word}

其中word可以是指定的任意字符,自左而右,查找sting变量所存储字符中,第一次出现的word,删除字符开头直至最后一次word出现处之间的所有字符

例子:

# mypath="sysconfig/network-scripts/ifcfg-eth"
# echo ${mypath##*/}                          
ifcfg-eth

${string%word*}

其中word可以是指定的任意字符,自右而左,查找sting变量所存储字符中,删除字符开头直至第一次word出现处之间的所有字符

例子:

# mypath="sysconfig/network-scripts/ifcfg-eth"  
# echo ${mypath%f*} 
sysconfig/network-scripts/ifc

${string%%word*}

其中word可以是指定的任意字符,自右而左,查找sting变量所存储字符中,删除字符开头直至最后一次word出现处之间的所有字符

例子:

# mypath="sysconfig/network-scripts/ifcfg-eth"
# echo ${mypath%%f*}
syscon

例子:url=http://www.oracle.com:80

取端口:${url##*:}

取协议:${url%%:*}

查找和替换:

${string/pattern/substi}

查找string变量所表示的字串中,第一次被pattern匹配到的字串,并以substi替换之

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath/eth0/ppp}
/etc/sysconfig/network-scripts/ifcfg-ppp

${string//pattern/substi}

查找string变量所表示的字串中,所有被pattern匹配到的字串,并以substi替换之

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath//s/p}     
/etc/pypconfig/network-pcriptp/ifcfg-eth0

${string/#pattern/substi}

以行首锚定的方式将pattern匹配至string所表示的字串上,如果能匹配,则以subsit替换之

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath/#//sys}  
/sys/etc/sysconfig/network-scripts/ifcfg-eth0

${string/%pattern/substi}

以行尾锚定的方式将pattern匹配至string所表示的字串上,如果能匹配,则以subsit替换之

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath/%eth0/sys}
/etc/sysconfig/network-scripts/ifcfg-sys

可使用?和*号

查找并删除:

${string/pattern}

删除pattern匹配到的第一次出现

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath/sysconfig}
/etc//network-scripts/ifcfg-eth0

${string//pattern}

删除pattern匹配到的所有出现

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath//s}       
/etc/yconfig/network-cript/ifcfg-eth0

${string/#pattern}

删除pattern匹配到的行首出现

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath/#\/}
etc/sysconfig/network-scripts/ifcfg-eth0

${string/%pattern}

删除pattern匹配到的行尾出现

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath/%eth0}
/etc/sysconfig/network-scripts/ifcfg-

字符串的大小写转换:

${string^^}

小写转换成大写

例子:

# netpath="/etc/sysconfig/network-scripts/ifcfg-eth0"
# echo ${netpath^^}    
/ETC/SYSCONFIG/NETWORK-SCRIPTS/IFCFG-ETH0

${string,,}

大写转换成小写

例子:

# path=/ETC/INIT.D/FUNCTIONS
# echo ${path,,}            
/etc/init.d/functions

实例:将下列文件的日期删除保留maillog文件名

#ls -l
-rw-------. 1 root root   1274 Nov 13 00:16 maillog1-20141111-finished.log
-rw-------  1 root root    825 Nov 30 02:05 maillog2-20141130-finished.log
-rw-------  1 root root   1437 Dec  3 06:18 maillog3-21231203-finished.log
#rename "finished" ""  执行批量改名
#test="maillog3-21231203-finished.log"
#echo ${test%finished*}.log
#!/bin/bash
for i in `ls *.log`; do
mv $i `echo ${i%finished*}.log`
done
#!/bin/bash
for I in `ls *.log` ; do
#mv $i `echo $i|sed ‘s/log/LOG/g‘`
mv $i `echo ${i/%log/LOG}`
done

rename改扩展名的方法:

#rename .jpg .JPG  *

实例:为脚本使用配置文件:

写个脚本,配置etc目录;

(1) 在配置文件中定义变量;

(2) 在脚本中source配置文件;

#!/bin/bash
[ -f /etc/sysconfig/network ] && source /etc/network/network
[-z "$HOSTAME" -o "$HOSTNAME" = ‘(none)‘ ] || HOSTNAME =‘localhost‘
/bin/hostname $HOSTNAME
/bin/hostname

[ ! -z "$HOSTAME" -a "$HOSTNAME" = ‘(none)‘ ] && HOSTNAME=‘localhost

注意:在字符串比较时,操作符两端得有空格;

trap命令:

实现脚本信号的捕获

不能捕获kill信号

trap ‘arg‘ SIGNAL

例如:trap ‘echo "quit"; exit 1‘ SIGINT

捕获exit退出信号然后输出quit信息

实例:在ping网络时可以捕获中断信号

#!/bin/bash
trap  "echo quit; exit"  SIGINT
for I in {1..254} ; do
    ping -c1 -w2 172.16.100.$i
done

mktemp命令:

mktemp [OPTIONS] filename.XXXXXXXX

-d: 创建临时目录

--tmpdir=/path/to/somewhere :指定临时文件所在的目录;

mktemp /tmp/abc.XXXX
自动把XXXX换成随机字符
tmpfile=`mktemp /tmp/abc.XXXX`
相对路径创建临时文件
mktemp abc.XXXXX
指定目录创建临时文件
mktemp --tmpdir=/var/tmp   abc.XXXX
指定目录创建临时文件夹
mktemp --tmpdir=/var/tmp  -d   abc.XXXX

install命令:

增强型复制命令

install [OPTIONS] SOURCE DEST
install [OPTIONS] SOURCE... DIR
install [OPTIONS] -t DIR SOURCE...

install -d DIR

-m MODE

-o OWNER

-g GROUP

实例:

#install /etc/issue /tmp/
复制文件到/tmp/
#install --mode=664 /etc/issue /tmp/
复制时指定权限
#install -d /tmp/newdir
创建目录


下面会记录一些bash shell中的基础知识。

时间: 2024-08-02 15:12:19

Bash Shell脚本编程笔记总结(二)的相关文章

Bash Shell脚本编程笔记总结(一)

本文是上课笔记总结,涉及细节知识点会在以后文章说明! bash脚本编程: 脚本程序:解释器解释执行: shell: 交互式接口:编程环境: shell: 能够提供一些内部命令,并且能通过PATH环境变量找到外部命令:把命令提交给内核启动为进程: 编程环境: 流程控制语句: 顺序执行: 循环执行: 选择执行: 条件测试:真.假 $? 命令的状态结果: 0: 真 1-255: 假 过程式的编程语言的元素:变量.流程.函数.数组 变量:局部变量.本地变量.环境变量.位置参数变量.特殊变量 变量: 数值

8.15_Linux之bash shell脚本编程入门篇(二)以及文件查找和压缩的使用

bash shell脚本编程入门篇(二) read命令的使用 作用: 使用read来把输入值分配给一个或多个shell变量: -p指定要显示的提示 -t TIMEOUT read从标准输入中读取值,给每个单词分配一个变量,所有剩余单词都被分配给最后一个变量 EX.read -p "Enter a filename:" FILE 条件选择之if的使用 if的作用:选择执行(注意:if语句可嵌套) 单分支 if 判断条件;then 条件为真的分支代码 fi EX.单分支案例 双分支 if

8.17_Linux之bash shell脚本编程入门篇(三)之循环以及函数function的使用

bash shell脚本编程入门篇(三)之循环 什么是循环执行? 将某代码段重复运行多次 重复运行多少次: 循环次数事先已知 循环次数事先未知 有进入条件和退出条件 相关命令:for, while, until,selet, for命令的使用 作用: 依次将列表中的元素赋值给"变量名"; 每次赋值后即执行一次循环体; 直到列表中的元素耗尽,循环结束 命令格式: for 变量名 in 列表; do 循环体(正常执行的执行命令) 语句1 语句2 语句3 ... done 列表生成方式: (

8.11_Linux之bash shell脚本编程入门篇(一)

什么是bash shell脚本编程? 答:Linux里面有多种shell,而CentOS和redhat的默认shell是bash shell.至于shell脚本,这个跟windows操作系统里面的批处理文件有点像(.bat的文件).不知道大家还是否记得Linux的哲学思想吗?其中有那么两点点:由众多目的的单一应用程序组成:一个程序只做一件事,且做好:组合目的的单一的小程序完成复杂的任务.我觉得shell脚本编程就很好的体现了这个哲学思想.shell脚本利用shell的功能缩写的一个"程序&quo

在Bash shell脚本编程中,如何正确无误获取到“脚本选项参数”和“脚本参数”呢?

Linnux 中有些命令的功能非常强大,主要是因为它支持的命令选项比较多.如:[ip]命令可以配置IP地址.路由条目的配置管理操作非常完善,该命令就可以完成[ifconfig]和[route]命令实现的所有功能.函数是单独的功能模块,如果函数能够接收选项参数,那么该函数的功能就变得丰富,且灵活.脚本也是一样. 那么linux中命令的格式又是怎么样的呢? [[email protected] ~]# command   [optons parameter1 | parameter2]...  pa

bash shell脚本编程学习总结

shell脚本编程 编译器-------解释器 静态语言:编译型语言,强类型(变量):事先转换成可执行格式.C/C++/JAVA/C# 动态语言:解释型语言,弱类型.边解释变执行.PHP,SHELL,python,perl 面向过程:shell,c:面向对象:java,python,perl,c++ 变量赋值:VAR_NAME = VALUE: bash变量类型: 环境变量:作用域为当前shell进程及其子进程. export VARNAME=VALUE或者 VARNAME=VALUE expo

Bash Shell脚本编程-变量知识

Shell:GUI  CLI 提供交互式接口:提高效率 命令行展开:~ ,{} 命令别名:alias 命令历史:history Globbing:*,?,[],[^] 命令补全:$PATH指定的目录下 路径补全:TAB键 管道:| 输入输出重定向:>    >> 提供编程环境: bash自动运行脚本机制 面向过程(以指令为中心组织数据)的编程模型 脚本编程 输入指令解决问题 程序是语句和表达式组成的 运行时根据一定流程来执行: 顺序执行 选择执行 循环执行 程序是指令+数据的 面向对象(

Linux Shell脚本教程:30分钟玩转Shell脚本编程(笔记)

资料链接 Shell有两种执行命令的方式: 交互式(Interactive):解释执行用户的命令,用户输入一条命令,Shell就解释执行一条. 批处理(Batch):用户事先写一个Shell脚本(Script),其中有很多条命令,让Shell一次把这些命令执行完,而不必一条一条地敲命令. shell脚本有循环和控制语句,为解释执行,不需要编译. 常见的Shell脚本解释器: 有bash.sh.csh.ksh等.我们说的Shell其实是指Shell脚本解释器. bash:Linux默认的shell

Bash Shell脚本编程-基础特性知识

Bash Shell的基础特性: 命令历史: history:shell内建命令 环境变量HISTFILE定义用户退出命令历史列表的存储位置 #echo $HISTFILE /root/.bash_history # echo $HISTFILESIZE   HISTFILE指向的文件持久留存的历史命令条目 1000 # echo $HISTSIZE           当前bash进程所留存的历史命令条目数 1000 # history -d 123            删除历史列表中的第1