博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux运维正则表达式之awk
阅读量:4982 次
发布时间:2019-06-12

本文共 2353 字,大约阅读时间需要 7 分钟。

一: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

 

转载于:https://www.cnblogs.com/wangqian723/p/7865483.html

你可能感兴趣的文章
最终版详细设计
查看>>
GenePix Pro 3.0
查看>>
html移动端 -- meta-模板 + rem
查看>>
js-控制浏览器和移动端的后退按钮 . popstate
查看>>
[QT][SQLITE]学习记录二 日期查询
查看>>
hdu 4455 Substrings
查看>>
web传参
查看>>
Python 查找binlog文件
查看>>
Git——如何将本地项目提交至远程仓库
查看>>
Convert CString to std::string
查看>>
3 - Selenium元素定位和操作
查看>>
GCC C语言 DLL范例,含源码
查看>>
冲刺第一天(补发)
查看>>
iOS开发Xcode中切换显示语言实现国际化
查看>>
C++模板学习
查看>>
nginx
查看>>
大数据平台搭建-hadoop集群的搭建
查看>>
安装一些包管理的记录 win10
查看>>
Android RecyclerView notifyDataSetChanged不起作用
查看>>
AndroidStudio3.0 Canary 8注解报错Annotation processors must be explicitly declared now.
查看>>