[ -f “input.txt” ]&&[ -s “input.txt” ]&&echo “input.txt exists and contains characters”
[]即判断语法,没必要用ifbash
注意[]先后必须有空格,各部分再由空格隔开,命令格式如此,不照作,就报错。app
&& || 逻辑运算符可用来代替then else。对于与操做符而言,前为真,则执行后面;对于或操做符而言,前为假,则执行后面spa
#!/bin/bash i=1 while read line do [ $i -ge 20 ]&&[ $i -le 50 ]&&echo $line i=$(($i+1)) done<input.txt
先设置一个行计数器,再读取文件的每一行,判断行号是否是大于等于20,且小于等于50,是的话就打印出该行 blog
<是逆向管道符排序
line只是变量,read后也可写其它名字,并不是必须这么命名字符串
定义的变量,要想使用,须加上$input
sed -i ‘s/apple/Apple/’ input.txt
sed即stram editor,用户没必要打开文件就可直接修改文件,参数-i是让修改直接做用于文件上数学
‘’是命令区,s表示替换,前为待替换字符串,后为替换字符串,记得最后也要有/it
David Math 95
Lily English 90
Lily Biology 83
Bob Biology 85
David English 88
Bob Math 87
1)问有多少学生?
io
cat input.txt|awk ‘{print $1}’|sort -u|wc -l
读入文件,结果给awk,只打印出第一列名字的字符,再进行去重(参数 -u)排序,再交给wc统计有多少行(参数 -l),即学生数量
2)谁英语成绩最好,并由低到高排序
cat input.txt|grep ‘English’|sort -r -k3
读入文件,结果给grep,找出包含English的行,再给sort,逆序排列(参数-r),键是第三列(参数-k3)
3)计算数学平均成绩
cat input.txt|grep ‘Math’|awk ‘{sum+=$NF}END{print sum/NR}’
读入文件,结果给grep,找出包含Math的行,再给awk,取每行最后一列的值,累加求和,所有处理后(END),用成绩之和除以记录数(NR,即number of records)