文章目录
awk
在awk中输出的自定义字符串 默认都当做变量,只有加双引号,文件名在执行框中也要加引号
- awk是一行一行执行的
- awk中的$1表示第一个字段,$2表示第二个字段,以此类推,
- $0表示一整行- 内置变量>
- FS设置域分隔符 等于-F(在没输出屏幕之前字段之间的分隔符)
- OFS 输出域分隔符 改变文件内容的分割符号,并且打印出来(显示到屏幕字段之间的分隔符)
- NF 浏览记录的域的个数,打印出每行有几列(列数)
- NR 已读的记录数(行数)
- ORS 输出记录分隔符(行分隔符)
变量 | 含义 |
---|---|
$0 | 当前记录 |
$1~ $n | 当前记录的第几列 |
FILENAME | 输入的文件名称 |
FS | 输入文件的字段分隔符(fields separator) |
RS | 输入文件的记录(每一行之间)的分隔符(record separator) |
NF | 当前行的字段数目(number of fields) |
NR | 当前记录所在的行号 |
OFS | 输出字段的分割符 |
ORS | 输出记录的分隔符 |
可以同时使用多个域分隔符,这时应该把分隔符写成放到方括号中,
- $awk -F’[ :/t]’ ‘{print $1,$3}’ test,表示以空格、冒号和tab作为分隔符。
- substr($n,m)
打印指定的列,并且从指定的第m个字符开始打印- substr($n,m,q) 打印指定的列,并且从指定的第n个字符开始打印,到q个字符停止
[root@centos7 ~]# ifconfig|awk ‘{if(NR == 2){print substr($2,1,10)}}’
10.0.0.131
[root@centos7 ~] awk ‘{sub($2,"a="NR);print > “abc”}’ abc 替换
[root@centos7 ~]cat abc
hs a=1 jsjs
hds a=2 isi
hshppls a=3 jswyuwe
hyeyeushs a=4 jspppjs
h555shs a=5 jsjs888dh
hshggghs a=6 jshehhjs
hshhhhshes a=7
hshshhsjs a=8 suuejejs
hshgewheues a=9 jejejsjs
hsujejeuhs a=10 77ieh2ssjs- 在awk中输出的自定义字符串 默认都当做变量,只有加双引号,文件名在执行框中也要加引号
- 匹配操作符(~), 用来在记录或者域内匹配正则表达式。
如$ awk ‘$1 ~/^root/’ test将显示test文件第一列中以root开头的行。
awk ‘{printf “%-8s %-10s\n”,$1,$4}’ log.txt
- 表示左对齐,没-表示右对齐- awk '{print $1}’ log.txt
输出第一列,大括号外用单引号。- awk -F ‘[ ,]’ ‘{print $1,$2}’ log.txt
#要用多个分割符隔开,使用[ ] ,外面用单引号括起来
[root@oldboyedu tmp]# awk ‘$2 ~ /th/ {print $2,$4}’ log.txt
this, a,
#~ 匹配符 / / 要匹配的内容写在斜杆内
[root@oldboyedu tmp]# awk ‘$3 !~ /3/’ log.txt
a a a d e
A a C D E
#显示第三列不含有3 的行
sub匹配第一次出现的符合模式的字符串,相当于 sed ‘s//’ 。
gsub匹配所有的符合模式的字符串,相当于 sed ‘s//g’ 。
- cat /etc/passwd | awk ‘NR= =5 ; NR==15’
==,==表示连续的行
==;==表示单个行
- 例子
把/etc/passwd文件中的第5到第15行的内容保存到/oldboy/test.txt中,(不低于三种方法)
答案: sed -n ‘5,15p’ /etc/passwd >/oldboy/test.txt
awk ‘NR= =5,NR==15’ /etc/passwd >/oldboy/test.txt
awk ‘NR>4&&NR<16’ /etc/passwd >/oldboy/test.txt
head -15 /etc/passwd |tail -11 >/oldboy/test.txt