shell编程小点笔记
linux shell脚本的一些基础点
1.标准输入和输出 0 1 2
0>;表示stdin标准输入
1>:表示stdout标准输出
2>:表示stderr错误输出
看个例子:
./start.sh >/dev/null 2>&1
1: start.sh 命令脚本
2:/dev/null 代表空设备文件
3:2> 表示stderr标准错误
4:& 表示等同于的意思,2>&1,表示2的输出重定向等同于1
5:1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于 "1>/dev/null"
因此,>/dev/null 2>&1也可以写成“1> /dev/null 2> &1”
那么本文标题的语句执行过程为:
1>/dev/null :首先表示标准输出重定向到空设备文件,也就是不输出任何信息到终端,说白了就是不显示任何信息。
2>&1 :接着,标准错误输出重定向 到 标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件。
一个相对完整的启动方式是
./command.sh >/dev/null 2>1& &(后台进程启动)
2.变量赋值建议不使用空格,因为会被当做命令来处理
3.(())和 $(())之间区别
(()):会将括号内的表达式做运算处理
$(()):当做运算处理,并将结果返回
看个例子;
if [ grep -P 'bin' fielname|wc -l ]; then do something ; fi
6.touch && echo && {}
touch aa 快速建立一个a文件
touch {1..10}? 快速建立文件名从1到10的文件
touch [1..10]? 不会建立任何的文件
echo *
1.若是文件夹有文件或目录,会输出所有的文件或目录
2.若是文件夹为空的话,会输出 *
echo ? //匹配单个字符的文件或是目录并输出
echo {1..10} 输出1-10的数字
通过以上的例子可以看出 {}会是做循环遍历,再看个。?
?? 若是中间包含 $aa 则解析该变量,得到1 ,若是不想解析 \$aa 这样输出的就是 $aa
8.参数变量
$#: 获取参数个数
$?: 上一个命令结果 成功是 0 失败为1
$@: 输出参数
$*: 输出参数
"$@" 返回一个数组?grep -o? 使用正则表达式
?grep -P? 使用Perl的正则表达式
?grep "line 5" filename -A1 :匹配到数据后再将下一行的数据显示出来
?grep "line 5" filename -B1 :匹配到数据后再将上一行的数据显示出来
?grep -n :匹配到数据后,除了显示匹配的内容外,另外显示行号
?
?
?13. sed 和 awk 较为复杂,另作笔记吧
?
?
?
?
??