Awk使用方法简介
==================AWK===================
AWK简介:awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入, 以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理;awk有3个不同版本: awk、nawk和gawk,未作特别说明,一般指gawk,gawk 是 AWK 的
GNU版本。
(1)域分隔符:awk在没有使用-F指定分割符时,默认以空格为分割符;
域分割 $0代表文本内容全文显示;
$1 代表分割第一个域;
$2 代表分割第二个域;
......
awk -F: 分割符为‘:’
eg: cat /etc/passwd | awk -F: '{print $1,$2,}'
(2) 打印报告头:
eg: cat /etc/passwd | awk -F: 'BEGIN{print "This is system user"}{print $1}' | more
打印结尾:
eg: cat /etc/passwd | awk -F: 'BEGIN{print "This is system user"}{print $1}END{"=================="}' | more
cat /etc/passwd |awk -F: ‘BEGIN{print “===============”}{print $1}END{print “==========”}’ |more
(3) awk 中的正则表达式:
1>匹配 ~
eg: cat /etc/passwd |awk '{if($1~/root/) print $0}'
cat /etc/passwd |awk ‘$0~/root/’
2>精确匹配:
eg: cat /etc/passwd | awk -F: '$1=="root"{print $0}'
3> 不匹配:
eg: cat /etc/passwd |awk '{if($1!~/root/) print $0}'
cat /etc/passwd | awk '$0 !~ /root/'
4>小于,小于或等于:
eg: cat /etc/passwd | awk -F: '{if($3<200) print $3}'
cat /etc/passwd | awk -F: '{if($3<=200) print $3}'
5>大于,大于或等于:
eg: cat /etc/passwd | awk -F: '{if($3>500) print $3}'
cat /etc/passwd | awk -F: '{if($3>=500) print $3}'
6> 匹配多个关键字:
eg:
cat /etc/passwd | awk -F: '$1 ~ /(root|user)/ {print $0}'
7> 匹配行首:
eg: cat test |awk -F: ‘{if($1~/^root/) print $0}’
cat test |awk -F: ‘$1~/^root/ {print $0}’
8> awk 使用 && ||
eg: cat /etc/passwd | awk -F: '{if($1=="root" && $5=="root") print $0}'
cat /etc/passwd | awk -F: '{if($1=="root" || $1=="sfsdfdsfds") print $0}'
(4) awk 中的NF与NR:
NF:浏览记录的域的个数(统计列的段数)
NR:统计列的行号
eg: cat test |awk -F: ‘{print NF}’ 输出一共有多少列
cat test |awk -F: ‘{print NF,NR}’ 输出一共有多少列及其行号
cat test |awk -F: ‘{print NR,$0}’ 输出全部内容,并在其前输出行号
awk '{if(NR<10 && $1~/root/) print $1}' /etc/passwd 行号小于10的,使用$1匹配root关键字
cat /etc/passwd | awk -F: '{print $NF}' 打印每段的最后一段
(5)awk替换:
eg:cat /etc/passwd | awk 'gsub(/root/,"alvinzeng") ' 将文中所有的root替换成alvinzeng,并输出了所有匹配的行
Awk使用方法简介的更多相关文章
- gawk使用方法简介
转载:gawk 使用方法简介 - 简书 (jianshu.com) gawk 是最初 Unix 系统上 awk 程序的 GNU 版本.相对于作为流式编辑器的 sed 而言,它提供了更为强大的编程语言特 ...
- 网络神器Greasemonkey(油猴子)使用方法简介+脚本分享【转载】
推荐下,觉得这个方法有用, 今天艾薇百科来介绍一下功能强大的Greasemonkey,俗称"油猴子",Greasemonkey可以自由定制网页,实现你想要的各种功能.堪称" ...
- Redis Cluster搭建方法简介22211111
Redis Cluster搭建方法简介 (2013-05-29 17:08:57) 转载▼ Redis Cluster即Redis的分布式版本,将是Redis继支持Lua脚本之后的又一重磅 ...
- Monte Carlo方法简介(转载)
Monte Carlo方法简介(转载) 今天向大家介绍一下我现在主要做的这个东东. Monte Carlo方法又称为随机抽样技巧或统计实验方法,属于计算数学的一个分支,它是在上世纪四十年代 ...
- C#——Marshal.StructureToPtr方法简介
目录 MarshalStructureToPtr方法简介 功能及位置 语法 参数说明 异常 备注 举例 本博客(http://blog.csdn.net/livelylittlefish)贴出作者(三 ...
- TabBarController创建及使用方法简介
TabBarController创建及使用方法简介 大致讲解一下TabBarController的创建过程: 首先,我们需要一些视图,如创建UIControllerView类型的view1,view2 ...
- delphi操作文本文件的方法简介
delphi操作文本文件的方法简介减小字体 增大字体 作者佚名来源不详发布时间2008-5-31 10:31:16发布人xuedelphi1 文件类型和标准过程 Delphi同Object ...
- iOS中常用的四种数据持久化方法简介
iOS中常用的四种数据持久化方法简介 iOS中的数据持久化方式,基本上有以下四种:属性列表.对象归档.SQLite3和Core Data 1.属性列表涉及到的主要类:NSUserDefaults,一般 ...
- jQuery的AJAX方法简介及与其他文件$符号冲突的解决办法
一.重要的jQuery AJAX方法简介 $.load(url) 从服务器载入数据 $.get(url,callback) 从服务器请求数据,并执行回调函数 $.post(url,data,callb ...
随机推荐
- Python Twisted系列教程18:Deferreds 全貌
作者:dave@http://krondo.com/deferreds-en-masse/ 译者: Cheng Luo 你可以从”第一部分 Twist理论基础“开始阅读:也可以从”Twisted 入 ...
- Python 小知识点(7)--类的创建方式
1. 创建类的第1方式(常用) class Foo(object): def func(self): print("Hello Foo") 2.创建类的第2方式 def func( ...
- Python 迭代器和生成器(转)
Python 迭代器和生成器 在Python中,很多对象都是可以通过for语句来直接遍历的,例如list.string.dict等等,这些对象都可以被称为可迭代对象.至于说哪些对象是可以被迭代访问的, ...
- oracle、sqlserver、mysql常用函数对比[to_char、to_number、to_date]
Oracle --> MySQL to_char(sysdat ...
- spring cloud zuul 配置(Robbin 和 熔断)
#启动负载均衡的重试机制,默认falsespring.cloud.loadbalancer.retry.enabled=true#Hystrix是否启用超时时间hystrix.command.defa ...
- Oracel官网下载各类版本的JDK
下载地址 http://www.oracle.com/technetwork/java/javase/downloads/index.html 拉到最下面 点download 在这里就可以下载到各个版 ...
- Java多线程-线程的生命周期
线程可以分为4个状态:New(新生),Runnable(可运行):为了方便分析,还可将其分为:Runnable与Running.blocked(被阻塞),Dead(死亡). 与人有生老病死一样,线程也 ...
- .net中delegate的使用
js中的写法: var GetEntityList = function(pParameter){ var list =[]; return list; }; var aEntityList = Ge ...
- [hdu4347]The Closest M Points(线段树形式kd-tree)
解题关键:kdtree模板题,距离某点最近的m个点. #include<cstdio> #include<cstring> #include<algorithm> ...
- Comet OJ - Contest #2 D 枚举重心
题面 思路: 函数f相当于是求一个点集f的直径,有一个性质是如果这个点集有多个直径一定相交于某一个点,或者一条边的中心,所以我们暴力枚举重心,计算以某个点为重心的点集对答案的贡献. 具体实现的时候,我 ...