Shell算术运算
1. let c=$A+$B
2. c=$[$A+$B]
3. c=$(($A+$B))
4. expr 表达式中要有空格,oprand opcode 命令引用
c=`expr $A + $B`
程序:
执行结果
执行状态结果
程序返回0 执行成功,非零出错
uid=0(root) gid=0(root) groups=0(root)
exit:退出脚本
if 0 为true 非0为false
if !grep "^$USERNAME\>" /etc/passwd &> /dev/null; then
echo "No such user: $USERNAME"
exit
fi
测试方法
[ expression ]
[[ expression ]]
test expression
[ $INT1 -eq $INT2 ]
[[ $INT1 -eq $INT2 ]]
test $INT1 -eq $INT2
文件测试
-e FILENAME :是否存在
-f FILE : 是否普通文件
-d File : 是否为目录
-r
-w
-x 测试该文件对当前执行脚本的用户是否有执行权限
[ -e /etc/inittab ]
[ -x /etc/rc.d/rc.sysinit ]
组合测试条件
-a and
-o or
!
if [ $# -gt 1 -a $# -le 3 ]
if [ $# -gt 1 ] && [ $# -le 3 ]
if [ $1 == 'q' -o $1 == 'Q' -o $1 == 'Quit' -o $1 == 'quit' ]
测试脚本语法是否正确
bash -n script.sh
bash -x script.sh 单步执行
脚本没有明确定义退出状态码,最后一条命令的退出码作为脚本的退出状态码
bash变量类型
1.本地变量(局部变量)
2.环境变量 env printenv export
3.位置变量 $1 脚本第一个参数
4.特殊变量
$? 程序执行状态码
$# 参数个数
$* 参数列表
$@ 参数列表
sed (Stream EDitor) 行编辑器
逐行读取到内存(模式空间)(类似grep可以正则处理),所以默认不影响原文件
处理结束后将模式空间打印到屏幕
sed `AddressCommand` file
Address:
1.startLine,Endline eg:1,100 从第一行到第100航
$ 最后一行
$-1 倒数第二行
2./RegExp/ eg:/^root/
3./pattern1/,/pattern2/ 第一次被pattern1匹配到的行开始,至第一次匹配到pattern2的行结束
4.LineNumber
5.startLine,+N 从startLine开始,向后的N行,一共N+1行
Command:
d 删除符合条件的行
p 显示符合条件的行
a \string 在指定的行后面追加新行,内容为string
i \string 在指定的行前面添加新行,内容为string
r File 将内容添加至符合条件的行处
w File 将地址指定范围内的行另存至指定的文件
s/pattern/string/修饰符 查询并替换,默认只替换第一个匹配的字符串
加修饰符
g: 全局替换
i: 忽略大小写
s###
s@@@ 三个相同就行
& 引用模式匹配到的整个字符串
-n 静默模式,不再打印模式空间里的内容中
-i 直接修改原文件
-e SCRIPT -e Script
-f 指定文件
sed -f /path/to/script file 用script处理file
-r 扩展regexp
sed -r 's@^[[:space:]]+@@g' /etc/grub.conf
sed 's@\(id:\)[0-9]\(initdefault:\)@\15\2@g' /etc/inittab
sed '/^$/d' /etc/inittab
sed 's@^#@@g' /etc/inittab
sed -r 's@^#[[:space:]]+@@g' /etc/inittab
sed -r 's@^[[:space:]]+#@@g' /etc/inittab
echo "/etc/grub" | sed -r 's@^(/.*/)[^/]+/?@\1@g'
echo "/etc/grub" | sed -r 's@^/.*/([^/]+)/?@\1@g'