数组
变量:存储单个元素的内存空间
数组:存储多个元素的连续的内存空间,相当于多个变量的集合
数组名和索引
索引:编号从0开始,属于数值索引
注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引
bash4.0版本之后开始支持
bash –version 查看bash版本
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 —不支持管道
显示所有数组:declare -a
引用数组元素:
${ARRAY_NAME[INDEX]} ${ 数组名[下标]}
echo ${title[0]} 显示数组元素title[0]
注意:省略[INDEX]表示引用下标为0的元素
引用数组所有元素:
${ARRAY_NAME[*]}
${ARRAY_NAME[@]}
数组的长度(数组中元素的个数):
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}
随机数组成的数组比较最大值最小值:冒泡算法
declare -a rand
for ((i=0;i<9;i++));do
rand[$i]=$RANDOM
if [ $i -eq 0 ];then
max=${rand[$i]}
min=$max
else
[ $max -lt ${rand[$i]} ] && max=${rand[$i]}
[ $min -gt ${rand[$i]} ] && min=${rand[$i]}
fi
done
echo all is ${rand[*]}
echo max is $max
echo min is $min
删除数组中的某元素:导致稀疏格式
unset ARRAY[INDEX]
删除整个数组:
unset ARRAY
如果数组是连续的数组的个数为n echo ${#name[*]}那么最后一个数组的下标为n-1
数组如果再循环中 :循环结束数组就结束了
管道传给循环开启子shell了
写入脚本不好使(脚本开启了子shell)
df -h|grep “/dev/sd”>df.log
脚本数组元素为var/log下.log结尾的文件 所有下标为偶数的文件中的内容行数之和
declare -a file
file=(/var/log/*.log)
declare -i a=0
for i in $(seq 0 $[${#file[*]}-1]);do
if [ $[$i%2] -eq 0 ];then
let a=$a+$(cat ${file[$i]}|wc -l)
fi
done
echo “lines $a”
字符串切片
${#var}:返回字符串变量var的长度 (查看字符串的长度var可以是数组的名称者 变量)
${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字 符开始,到最后的部分,offset的取值在0 到 ${#var}-1 之间(bash4.2后,允许为负值)
${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个 字符)的字符开始,长度为number的部分
${var: -length}:取字符串的最右侧几个字符
注意:冒号后必须有一空白字符
${var:offset:-length}:从最左侧跳过offset字符,一直向右取到距离最右侧lengh个字 符之前的内容
${var: -length:-offset}:先从最右侧向左取到length个字符开始,再向右取到距离最 右侧offset个字符之间的内容
注意:-length前空格 版本 (7可以用6不能)
从左到右
基于模式取字符串
${var#*word}:其中word可以是指定的任意字符
功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删 除字符串开头至第一次出现word字符之间的所有字符
${var##*word}:同上,贪婪模式,不同的是,删除的是字符串开头至最后 一次由word指定的字符之间的所有内容
示例: file=“var/log/messages”
${file#*/}: log/messages
${file##*/}: messages
从右往左
${var%word*}:其中word可以是指定的任意字符
功能:自右而左,查找var变量所存储的字符串中,第一次出现的word, 删 除字符串最后一个字符向左至第一次出现word字符之间的所有字符 file=”/var/log/messages”
${file%/*}: /var/log
${var%%word*}:同上,只不过删除字符串最右侧的字符向左至最后一次出现 word字符之间的所有字符;
查找替换
${var/pattern/substr}:查找var所表示的字符串中,第一次被pattern所匹 配到的字符串,以substr替换之
${var//pattern/substr}: 查找var所表示的字符串中,所有能被pattern所匹 配到的字符串,以substr替换之
${var/#pattern/substr}:查找var所表示的字符串中,行首被pattern所匹 配到的字符串,以substr替换之
${var/%pattern/substr}:查找var所表示的字符串中,行尾被pattern所匹 配到的字符串,以substr替换之
查找并删除 (替代的为空)
${var/pattern}:删除var所表示的字符串中第一次被pattern所匹配到的字符串 ${var//pattern}:删除var所表示的字符串中所有被pattern所匹配到的字符串 ${var/#pattern}:删除var所表示的字符串中所有以pattern为行首所匹配到的 字符串
${var/%pattern}:删除var所表示的字符串中所有以pattern为行尾所匹配到的 字符串
字符大小写转换
${var^^}:把var中的所有小写字母转换为大写
${var,,}:把var中的所有大写字母转换为小写
变量赋值 :相当于吧str为空字符串当做str没有配置
高级变量
Shell变量一般是无类型的,但是bash Shell提供了declare和typeset两个命令 用于指定变量的类型,两个命令是等价的
declare [选项] 变量名 和typeset等价
-r 声明或显示只读变量
-i 将变量定义为整型数
-a 将变量定义为数组
-A 将变量定义为关联数组
-f 显示已定义的所有函数名及其内容
-F 仅显示已定义的所有函数名
-x 声明或显示环境变量和函数
-l 声明变量为小写字母 declare –l var=UPPER
-u 声明变量为大写字母 declare –u var=lower
eval命令将会首先扫描命令行进行所有的置换,然后再执行该命令。该命令适用于 那些一次扫描无法实现其功能的变量.该命令对变量进行两次扫描
间接变量引用
如果第一个变量的值是第二个变量的名字,从第一个变量引用第二个变量的值 就称为间接变量引用
variable1的值是variable2,而variable2又是变量名,variable2的值为value, 间接变量引用是指通过variable1获得变量值value的行为
variable1=variable2
variable2=value
bash Shell提供了两种格式实现间接变量引用
eval tempvar=\$$variable1
示例:eval echo \$$name —eval echo $`echo $name`
tempvar=${!variable1}
命令存到一个变量里不是写死的
mktemp命令:创建并显示临时文件,可避免冲突 — 一般放到变量里使用
mktemp [OPTION]… [TEMPLATE]
TEMPLATE: filenameXXX
X至少要出现三个 X为大写
-d: 创建临时目录
-p DIR或–tmpdir=DIR:指明临时文件所存放目录位置
安装复制文件
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 组
示例:
install -m 700 -o wang -g admins srcfile desfile
install –m 770 –d /testdir/installdir
复制/etc/shadow文件 到/data/下改名为password.txt 并吧权限设置为700所有者设置为wang所有组为bin
mkdir创建是设置权限
expect 是由Don Libes基于Tcl( Tool Command Language )语言开发的, 主要应用于自动化交互式操作的场景,借助Expect处理交互的命令,可以将交互 过程如:ssh登录,ftp登录等写在一个脚本上,使之自动化完成。尤其适用于需 要对多台服务器执行相同操作的环境中,可以大大提高系统管理人员的工作效率
expect 语法:
expect [选项] [ -c cmds ] [ [ -[f|b] ] cmdfile ] [ args ]
选项
-c:从命令行执行expect脚本,默认expect是交互地执行的
示例:expect -c ‘expect “\n” {send “pressed enter\n”} 期望收到回车\n 收到就send “pressed enter\n”
-d:可以输出输出调试信息
示例:expect -d ssh.exp
expect中相关命令
spawn:启动新的进程
send:用于向进程发送字符串
expect:从进程接收字符串
interact:允许用户交互
exp_continue 匹配多个字符串在执行动作后加此命令
单一分支模式语法:
expect “hi” {send “You said hi\n”}
匹配到hi后,会输出“you said hi”,并换行
多分支模式语法:
expect “hi” { send “You said hi\n” } \
“hehe” { send “Hehe yourself\n” } \
“bye” { send “Good bye\n” }
匹配hi,hello,bye任意字符串时,执行相应输出。等同如下:
expect {
“hi” { send “You said hi\n”}
“hehe” { send “Hehe yourself\n”}
“bye” { send “Good bye\n”} }
示例
#!/usr/bin/expect —首棒机制不是bash,expect是一种语言
spawn scp /etc/fstab 192.168.8.100:/app —spawn激活后面的命令
expect {
“yes/no” { send “yes\n”;exp_continue } — 捕获yes/no就向命令发送yes exp_contimue表示继续执行捕获
“password” { send “magedu\n” } —捕获到password 就向命令发送magedu
}
expect eof —结束代码
如果执行比较慢就vim /etc/ssh/sshd_config
把ssh服务 的GSSAPIAuthentication yes yes改为no
#UseDNS no 启用(去掉#)
改完后重启sshd服务systemctl restart sshd
实现自动登录后继续交互
#!/usr/bin/expect
spawn ssh wang@192.168.147.69
expect {
“yes/no” { send “yes\n”;exp_continue }
“password” { send “magedu\n” }
}
interact ——继续交互
#expect eof
#!/usr/bin/expect
set ip 192.168.8.100 变量ip赋值为192.168.2.100
set user root 变量user赋值为root
set password magedu 变量password赋值为magedu
set timeout 10 超时时长10秒
spawn ssh $user@$ip 启用连个变量
expect {
“yes/no” { send “yes\n”;exp_continue }
“password” { send “$password\n” }
}
interact
#!/usr/bin/expect
set ip [lindex $argv 0] 第一个位置参数 [lindex $argv 0]
set user [lindex $argv 1] 第二个
set password [lindex $argv 2] 第三个
spawn ssh $user@$ip
expect {
“yes/no” { send “yes\n”;exp_continue }
“password” { send “$password\n” }
}
interact
#./ssh3.exp 192.168.8.100 root magedu 注释语法
本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/98390