内容摘要:
- 打印某行到某行之间的内容
- sed转换大小写
- sed在某一行最后添加一个数字
- 删除某行到最后一行
- 打印1到100行含某个字符串的行
- awk 中使用外部shell变量
- awk 合并一个文件
- 把一个文件多行连接成一行
- awk中gsub函数的使用
- awk 截取指定多个域为一行
- 过滤两个或多个关键词
- 用awk生成以下结构文件
- awk用print打印单引号
- 合并两个文件
- awk的BEGIN和END
- awk的参考教程
一、打印某行到某行之间的内容:
答: sed -rn '/(abcfd)/,/(rty)/'p test.txt
二、sed 如何转换大小写字母
答:sed 's/\b[a-z]/\u&/g' filename
答:sed 's/[a-z]/\u&/g' filename
答:sed 's/[A-Z]/\l&/g' filename
三、sed在文件中某一行最后添加一个数字
答:sed -r 's/(^a.*)/\1 12/' test 或者 sed -r 's/(^a.*)/& 12/' test
四、sed删除某关键字的下一行到最后一行
- 如: A=44echo "ABCD" | awk -v GET_A=$A ’{print GET_A}’
- 说明:-v选项用于定义参数,这里表示将变量A的值赋予GET_A。
- 有多少个变量需要赋值,就需要多少个-v选项。与之等价的:应用于脚本中:
sort -n filename |awk -F ':' '{print $1}'|uniq >id.txt
awk -v id2=$id -F ':' '$1==id2 {print $2}' filename // 另外的方式为: awk -F ':' '$1=="'id'" {print $2}' filename
- 实现的命令为: awk 'NR==FNR{a[$1]=$2}NR>FNR{print $0,a[$1]}' 1.txt 2.txt
- 解释:NR表示读取的行数(两个文件的总行数), FNR表示读取的当前行数(读取2.txt时清零),大家可以运行这个命令 awk '{print NR,FNR}' 1.txt 2.txt,比较NR和FNR
- 所以其实NR==FNR 就表示读取1.txt的时候。 同理NR>FNR表示读取2.txt的时候
- 数组a其实就相当于一个map
八、把一个文件多行连接成一行
九、awk中gsub函数的使用
- passwd文件中把所有www替换为abc:awk 'gsub(/www/,"abc")' /etc/passwd
- 替换$1中的www为abc: awk -F ':' 'gsub(/www/,"abc",$1) {print $0}' /etc/passwd
awk -F ':' -v a=$i '{printf $a " "}' /etc/passwd
十、grep 或 egrep 或awk 过滤两个或多个关键词
- 找出文件(filename)中包含123或者包含abc的行:grep -E '123|abc' filename
- 用egrep同样可以实现:egrep '123|abc' filename
- awk 的实现方式:awk '/123|abc/' filename
1,1,0000000001,0000000001,0000000001,0000000001,0000000001,0000000001,2005100110101
2,2,0000000002,0000000002,0000000002,0000000002,0000000002,0000000002,2005100110101
- 答:awk 'BEGIN{for(i=1;i<=10;i++)printf("%d,%d,%010d,%010d,%010d,%010d,%010d,%010d,%d\n",i,i,i,i,i,i,i,i,strftime("%Y%m%d%H%M%S"))}'
- 如果要写多几行,就把这里的10改成需要的数字即可,例如:20 {for(i=1;i<=20;i++)
- 不用脱义,就多写几个单引号、双引号: awk 'BEGIN{print "a'"'"'s"}'
- 用脱义,脱义的是单引号: awk 'BEGIN{print "a'\''s"}'
- 用脱义,脱义的是双引号:awk 'BEGIN{print "a\"s"}'