函数
完成特定功能的代码片段 函数必须先定义才能使用
优点:避免重复的代码
取消函数 unset
关联数组
declare [ ] 数组声明
-a 定义为数组
-A 定义为关联数组
指定索引赋值
数组名[ ]=变量值
访问数组 echo ${数组名[0]}访问数组中的第一个元素
echo ${数组名[@]}访问数组中所有的元素 等于 echo ${数组名[*]}
echo ${#数组名[@]}统计元素的个数
echo ${!数组名[@]}打印数组的所有索引
正则表达式
^ 行首定位符
$ 行尾定位符
. 匹配单个字符
* 匹配前导符0到多次
.* 匹配任意多个字符
[ ] 匹配方括号中任意一个字符
[ - ] 匹配指定范围内的一个字符
\ 转义符
\< 词首定位符
/> 词尾定位符
\(\) 匹配后的标签
拓展 + 匹配一次或者多次前导字符
?匹配一次或者0次前导字符
a|b 匹配a或b
x{m}字符x重复m次
x{m,}字符x重复至少m次
x{m,n}字符x重复m到n次
()字符组
特殊字符正则表达式
[[:alpha:]] 匹配任何字母 无论大小写
[[:alnum:]] 匹配任何字母 无论大小写 还匹配数字0~9
[[:blank:]] 匹配空格和制表符
[[:digit:]] 匹配数字0~9
[[:upper:]] 匹配大写字母
[[:lower:]] 匹配小写字母
[[:punct:]] 匹配标点符号
[[:print:]] 匹配可打印字符
^[0-9]+$ 匹配正数数字
\w 匹配字母或数字或下划线或汉字 等价于 '[^A-Za-z0-9_]'(匹配汉字需要看操作系统和应用环境而定)
\s 匹配任意的空白符 (包括水平制表符)
\d 匹配数字
\b 匹配单词的开始或结束
sed 用于自动编辑一个或多个文件 简化对文件的反复操作编写转换程序等 非交互·式编译器 一次处理一行内容
sed -r 支持扩展正则 即使没用扩展正则也不会有任何影响
sed -n 不打印静默输出
sed -f < 文件 >
sed -r '1~2d' passwd 删除奇数行
sed -r '0~2d' passwd 删除偶数行
插入命令 -i 修改命令 -c 9c修改第九行
awk 是一种编程语言 处理过程为 依次对每一行进行处理 然后输出 默认分隔符是空格或者tab键
-F"" 指定分隔符
BEGIN{ } { } END{ }
行处理前的动作 行内容处理动作 行处理之后的动作
awk 按记录处理 一行是一条记录 因为awk默认以换行符分开的字符串是一条记录(默认\n换行符)
字符 以字段分隔符的字符串 默认单个或多个 空格 或者 tab键
$0 表示整行
NF 统计字段的个数
$NF 表示最后一列的信息
RS 输入记录分隔符
ORS 输出记录分隔符
NR 打印记录号 (行号)
FNR 按不同文件打印行号
FS 输入字段分隔符 默认为空格
OFS 输出字段分隔符 默认为一个空格
$1 第一个字段 $2 第二个字段
awk 关系运算符
实现字符串的完全相等需要使用 == 不等于!=
sort 排序 默认升序 -k 指定列数 -r 降序 -n 以数值来排序
i++ 先赋值再运算
++i 先运算再赋值
expect用来实现自动交互式命令
expect #!/usr/bin/expect expect的解释器
spawn执行expect之后执行的内部命令开启一个会话 用来执行expect的交互命令
expect判断输出结果是否包含某项字符串 相当于捕捉命令的返回的提示
send执行交互动作 将交互的命令进行发送给交互指令 字符串结汇加上\r 相当于回车
interact执行后保持交互状态 需要等待手动退出交互状态 如果不加这项 交互完成自动退出
exp_continue 继续执行接下来的操作
timeout 返回设置超时时间
expect eof 继续执行