博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
awk工具-解析1
阅读量:5338 次
发布时间:2019-06-15

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

awk处理方式:

1.行处理机制,每次处理一行,跟sed很相近,但是awk还能够对每行进行切片处理

基本格式:

awk [options]  'command' file(s)

command:pattern {awk 操作命令}两部分组成

pattern:正则表达式,逻辑表达式

awk操作指令是用{ }代表代码段:

操作指令:print(), printf()

控制指令:if(){... } else{...},while(){...}

awk内置参数应用:

awk内置变量1:

$0 代表整行

$1代表第一个字段

$2代表第二个字段

awk内置参数:分隔符

option:-F(默认为空格)

awk -F ':'  '{print $3}' passwd

如果想同时打两个字段: 有两种方式(中间加,或者打印空格)

awk -F ':'  '{print  $1,$3}' passwd

awk -F ':'  '{print $1"  " $3}' passwd

可以增加说明字段:

awk -F ':' '{print "USER" $1}' passwd

内置变量2:

NR :行号

NF:每行的字节总数

awk -F ':' '{print  NR,NF}' passwd

例子:显示passwd每行的行号,每行的列数,以及用户名(用print和printf两种方式) 

awk -F ':' '{print "Line: " NR,"Column :" NF,"User:" $1}' passwd

因为printf是函数,则按照函数输出来写:

awk -F ':' '{printf("Line:  %s  Column :  %s User: %s\n",NR,NF,$1)}' passwd

要有换行

例子2:显示passwd中用户ID大于100的行号和用户名(if ...else...)

awk -F ':' '{if($3>100) print "Line: " NR,"User:" $1}'  passwd

例子3:在服务器log中找出ERROR的错误时间信息,一般是第一字段

这时候首先找出ERROR出现的行,在打印第一字段

sed -n ' /ERROR/p'  log名字 |awk  '{ print $1}'

还可以: 

awk '/ERROR/{print $1}' log名字  先用正则定位在打印

 

 

 

转载于:https://www.cnblogs.com/shamoguzhou/p/7092175.html

你可能感兴趣的文章
jQuery上传插件Uploadify 3.2在.NET下的详细例子
查看>>
如何辨别一个程序员的水平高低?是靠发量吗?
查看>>
新手村之循环!循环!循环!
查看>>
正则表达式的用法
查看>>
线程安全问题
查看>>
下拉刷新
查看>>
linux的子进程调用exec( )系列函数
查看>>
MSChart的研究
查看>>
C# 索引器
查看>>
MySQLdb & pymsql
查看>>
zju 2744 回文字符 hdu 1544
查看>>
delphi 内嵌汇编例子
查看>>
【luogu P2298 Mzc和男家丁的游戏】 题解
查看>>
前端笔记-bom
查看>>
MATLAB作图方法与技巧(一)
查看>>
上海淮海中路上苹果旗舰店门口欲砸一台IMAC电脑维权
查看>>
Google透露Android Market恶意程序扫描服务
查看>>
给mysql数据库字段值拼接前缀或后缀。 concat()函数
查看>>
迷宫问题
查看>>
【FZSZ2017暑假提高组Day9】猜数游戏(number)
查看>>