一:Linux运维正则表达式之sed
AWK是一个优良的文本处理工具,Linux及Unix环境中现有的功能最强大的数据处理引擎之一。
1.选项|参数:
-F fs or --field-separator fs
指定输入文件折分隔符,fs是一个字符串或者是一个正则表达式,如-F:。-v var=value or --asign var=value赋值一个用户定义变量。-f scripfile or --file scriptfile从脚本文件中读取awk命令。-mf nnn and -mr nnn对nnn值设置内在限制,-mf选项限制分配给nnn的最大块数目;-mr选项限制记录的最大数目。这两个功能是Bell实验室版awk的扩展功能,在标准awk中不适用。-W compact or --compat,?-W traditional or --traditional在兼容模式下运行awk。所以gawk的行为和标准的awk完全一样,所有的awk扩展都被忽略。-W copyleft or --copyleft,?-W copyright or --copyright打印简短的版权信息。-W help or --help,?-W usage or --usage打印全部awk选项和每个选项的简短说明。-W lint or --lint打印不能向传统unix平台移植的结构的警告。-W lint-old or --lint-old打印关于不能向传统unix平台移植的结构的警告。-W posix打开兼容模式。但有以下限制,不识别:\x、函数关键字、func、换码序列以及当fs是一个空格时,将新行作为一个域分隔符;操作符**和**=不能代替^和^=;fflush无效。-W re-interval or --re-inerval允许间隔正则表达式的使用,参考(grep中的Posix字符类),如括号表达式[[:alpha:]]。-W source program-text or --source program-text使用program-text作为源代码,可与-f命令混用。-W version or --version打印bug报告信息的版本。二.实例练习:
-F 定义字段分隔符
[root@localhost ~]# awk -F: '{print $1,$4}' test.txt 取每行第一和四个分割[root@localhost ~]# awk -F: '{print $1,$4}' test.txt 去最后一段NR行号[root@localhost ~]# [root@localhost ~]# awk -F: 'NR<=2 || NR>=7{print NR,"------",$1}' test.txt[root@localhost ~]# awk -F: '/nologin$/{print $1}' test.txt #打印以nologin结尾行的第一个字段
[root@localhost ~]# awk -F: '$1~/^r.*t$/{print NR,$3}' test.txt 打印第一字段以r开头以t结尾
[root@localhost ~]# awk -F: '$1=="root"{print NR,$3}' test.txt 匹配第一字段为root[root@localhost ~]# awk -F: '$3 >= 7{print NR,$1}' test.txt 打印uid大于等于7的字段
[root@localhost ~]# [root@localhost ~]# count=7[root@localhost ~]# awk -v x=$count -F: '$3 >= x{print NR,$1}' test.txt 自定义 #一个conut变量可以更改conut=几,打印的结果也随之改变[root@localhost ~]# ifconfig | awk 'NR==2{print $2}' #取IP地址
[root@localhost ~]# ip_addr=`ifconfig | awk 'NR==2{print $2}'`
[root@localhost ~]# echo $ip_addr #保存ip地址[root@localhost ~]# cat a.txt |sort |uniq #查看并去重
[root@localhost ~]# cat a.txt |sort |uniq -c #查看去重数 [root@localhost ~]# cat test.txt |cut -d: -f1,3 查看第一和第三部分[root@localhost ~]# du -sh /etc 查看目录大小
36M /etc[root@localhost ~]# find / -type f 文件类型
[root@localhost ~]# find / name "*.txt" 找出所有.txt结尾的文件[root@localhost ~]# find / -size +30M 找出/下大于30M的文件[root@localhost ~]# find / -size -30M -size +10M 大于10M小于30M[root@localhost ~]# find / -size +2M -type f -name \*.txt