数组,字符串切片,高级变量

数组

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

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

数组名和索引

索引:编号从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/98389

(0)
张陆禄张陆禄
上一篇 2018-05-13
下一篇 2018-05-13

相关推荐

  • 第一周作业

    本周作业 1、描述计算机的组成及其功能。 2、按系列罗列Linux的发行版,并描述不同发行版之间的联系与区别。 3、描述Linux的哲学思想,并按照自己的理解对其进行解释性描述。 4、说明Linux系统上命令的使用格式;详细介绍ifconfig、echo、tty、startx、export、pwd、history、shutdown、poweroff、rebo…

    Linux笔记 2018-05-12
  • Tomcat的简介和应用

    tomcat的配置文件;tomcat的虚拟主机;tomcat的图形管理界面;tomcat的负载均衡;

    2018-07-16
  • linux关于grep 与 正则表达式的那些事

    首先要记住的是: 正则表达式与通配符不一样,它们表示的含义并不相同! 正则表达式只是一种表示法,只要工具支持这种表示法, 那么该工具就可以处理正则表达式的字符串。vim、grep、awk 、sed 都支持正则表达式,也正是因为由于它们支持正则,才显得它们强grep (缩写来自Globally search a Regular Expression and P…

    2018-04-08
  • 运维自动化部署

    CentOS系统启动流程:bootloader(引导模式)>kernel(内核)>rootfs(根文件系统)>/sbin/init(开机启动服务) 安装程序启动过程:MBR:isolinux/boot.cat stage2: isolinux/isolinux.bin 配置文件:isolinux/isolinux.cfg每个对应的菜单…

    Linux笔记 2018-06-10
  • 如何在VMware下安装CentOS7

    图文详解安装Centos7系统

    2018-07-20
  • 1

           

    Linux笔记 2018-04-07