10分钟精通shell编程!
一、输入输出重定向
标准输入 /dev/stdin 0 键盘
标准输出 /dev/stdout 1 显示器
标准错误输出 /dev/stderr 2 显示器
#设备文件名 #文件描述符 #默认设备
1)输出重定向
把应该输出到屏幕的输出,重定向到文件。
> 覆盖 >> 追加
ls > aa 覆盖到a ls >> aa 追加到aa
ls gdlslga 2>>aa 错误信息输出到aa 强调:错误输出,不能有空格
ls &>aa 错误和正确都输入到aa
掌握(查看系统版本:uname -r)
ls >> aa 2>>bb 正确信息输入aa,错误信息输入bb
ls >> aa 2>&1 错误和正确都输入到aa,可以追加
2>&1 把标准错误重定向到标准正确输出
二、多命令顺序执行
1)命令1 ; 命令2;命令3 命令123顺序执行。之间没有任何关系如:cd;ls ;date #date 用于打印当前系统时间
2)命令1 && 命令2 命令1正确执行后,命令2才会执行
3)命令1 || 命令2 命令1执行不正确,命令2才会执行,也就是说:如果第一个命令正确执行,那么第二个命令就不会执行了!
类test测试:
a)ls && echo "Yes" || echo "No"
b)ls skdjfkdj && echo "Yes" || echo "No"
lsaa && echo "cunzai" || echo "bu cunzai!" 执行ls aa,判断如果正确,输出“存在”。如果不存在,输出“不存在”
三、管道符:两个命令之间有联系,
命令1 | 命令2 命令1的执行结果,作为命令2的执行条件
注意:第一条命令一定得有输出
netstat-tlun | grep 80 查询监听的端口号,并查看80端口是否启动。
附:netstat-tlun列出监听了多少个端口;
grep提取命令,如 grep80 #提取包含有80的行
80是Apache的端口
ls -l /etc/ | more 分屏显示ls内容
ls-l /etc/ | grep vim
四、变量:
Linux的Shell将所有的变量都识别程字符串型
设置变量的目的:像程序脚本中传值。
1分类
本地变量、环境变量、位置参数变量、预定义变量
2本地变量
1)声明 变量名=变量值 注意:=号左右不能有空格 aa=123
2)调用 echo $变量名
3)查看变量 set 查看所有变量,包括环境变量和本地变量
4)删除 unset 变量名
3变量设定规则
1)变量以等号连接值,等号不能有空格
2)变量名由数字和字母和下划线组成,不能以数字开头
3)变量值中有空格,用引号括起来如:aa=”helloworld” #其中不能有符号!!!
4)双引号内,有特殊字符。如$
5)单引号中特殊字符无含义
6)在变量值中,可以使用\转义符
7)变量值可以直接调用系统命令。 `命令` $(命令)
如cc=`ls/dev` # ` 是反引号,Esc键下的那个
或者:cc=$(ls/dev) 作用相同,推荐!
调用:echo$cc
8)变量值可以累加 aa=123 aa="$aa"456 echo $aa --->123456
9)环境变量一定设为大写
环境变量配置文件
/etc/bashrc 所有用户生效
/etc/profile
~/.bashrc只对指定用户生效
~/.bash_profile
五、位置参数变量
$0 命令自己
$1 第一个参数
$2 第二个参数
$9 第九个参数
$? 上一个命令的返回值:0 上一个命令正确执行;非0 上一个命令不正确
$# 统计命令之后的参数个数 $* 返回所有参数 $n 位置参数变量
六、常见命令 常用命令
1 行提取命令grep
选项: -v 反向选择
-n 提取时,显示行号
举例:
grep "[^a-z]hen" test.txt
oo前不是小写字母的行匹配。 注意:和开头没有关系
附:也可以结合以前的内容:grep-n "[^a-z]hen" test_rule.txt
中括号代表一个字母,^代表取反,a-z代表小写字母a到z
grep “\.$” test.txt
匹配以.结尾的行
附:在正则表达式中$代表行尾;
\ 代表转义符,表示,将其后紧跟字符的特殊含义消失!
Linux中行尾的空格附,也可以作为一个字符,一定要记住!这是一些脚本发生错误的原因!
grep "^[^A-Za-z]" test.txt
匹配不以字母开头的行 注意:所有字母不能这样写 A-z
附:
^在中括号外面代表行首
grep"^[^a-zA-Z]" test_rule.txt #这样也可以
grep “^$” test.txt
匹配空白行
grep "oo*" test.txt
匹配最少一个o
附:o*代表着*前面的这个o可以重复0到无数多次
还可以这样用:grep"hh*o" test_rule.txt
这样: grep"ooo" test_rule.txt
echo命令
echo -e “输出内容”
-e 识别格式化打印内容
echo -e “1\t2\t3” 打印tab键
echo -e "\e[1;31m this is red text \e[0m" 输出红色字体
\e[ 格式标志
1;31m 指定颜色 #30到39之间的数字
0m 恢复颜色(重置)
附:30m=黑色,31m=红色,32m=绿色,33m=黄色,34m=蓝色,35m=洋红, 36m=青色,37=白色
echo -e “\e[1;42 background \e[0m”
判断字符串
[-z 字符串] 判断字符串是否为空,变量值没有内容/为空则是真