Linux awk使用方法~~整理
目录
awk行处理方式
awk和sed一样,一次处理一行内容;也可以对每行进行切片处理
awk命令格式
命令行格式
$ awk [options] 'command' files
脚本格式
$ awk -f scirpt_file files
基本格式
$ awk [options] 'command' files
command 由两部分组成,分别是
1、pattern,可以是正则表达式或者逻辑判断式
2、{ awk 命令 } 花括号括起来的是代码段
awk内置变量
| 变量 | 含义 |
| $0 | 当前记录(整行的记录) |
| $1~$n | 当前记录的第几列 |
| FILENAME | 输入的文件名称 |
| FS | 输入文件的字段分隔符(Fields Separator) |
| RS | 输入文件的记录(每一行之间)的分隔符(Record Separator) |
| NF | 当前行的字段数目(Number of Fields) |
| NR | 当前记录所在的行号 |
| OFS | 输出字段的分隔符 |
| ORS | 输出记录的分隔符 |
awk函数
| 函数声明 | 含义 |
| length(str) | 返回str中字符的个数 |
| int(num) | 返回num的整数部分 |
| index(str1, str2) | 返回str2在str1中的索引,如果不存在就返回0 |
| split(str, arr, separator) | 使用separator作为分隔符,将str切分为数组保存到arr中,返回数组的元素个数 |
| printf(fmt, args) | 根据fmt格式化args,并输出结果 |
| sprintf(fmt, args) | 根据fmp格式化args,并返回格式化后的字符串 |
| substr(str, pos, len) | 返回str中从pos开始,长度为len个字符的子字符串 |
| tolower(str) | 返回str转换为小写字母后的副本 |
| toupper(str) | 返回str转换为大写字母后的副本 |
测试数据
-> # cat data.txt
小红 female 一年级 BeiJing 90 Yes
小花 female 一年级 ShangHai 55
小明 male 三年级 BeiJing 90
小可 female 一年级 ChongQing 70
小林 male 一年级 ChongQing 90 Yes
小飞 male 二年级 GuangDong 65
小波 male 一年级 HangZhou 90 No
小康 male 四年级 ShenZhen 65 No
小雷 male 一年级 FuJian 70
小冰 female 五年级 BeiJing 90
测试awk变量和函数
打印每一行的行号、字段数、以及每一行的内容
-> # awk '{print "row:" NR "\t" "fields:" NF "\t" $0}' data.txt
row:1 fields:6 小红 female 一年级 BeiJing 90 Yes
row:2 fields:5 小花 female 一年级 ShangHai 55
row:3 fields:5 小明 male 三年级 BeiJing 90
row:4 fields:5 小可 female 一年级 ChongQing 70
row:5 fields:6 小林 male 一年级 ChongQing 90 Yes
row:6 fields:5 小飞 male 二年级 GuangDong 65
row:7 fields:6 小波 male 一年级 HangZhou 90 No
row:8 fields:6 小康 male 四年级 ShenZhen 65 No
row:9 fields:5 小雷 male 一年级 FuJian 70
row:10 fields:5 小冰 female 五年级 BeiJing 90
打印所有的人名、城市
-> # awk '{print $1 "\t" $4}' data.txt
小红 BeiJing
小花 ShangHai
小明 BeiJing
小可 ChongQing
小林 ChongQing
小飞 GuangDong
小波 HangZhou
小康 ShenZhen
小雷 FuJian
小冰 BeiJing
使用printf来格式化打印用户信息
-> # awk -F ':' '{printf("Line:%s Fields:%s User:%s\n", NR, NF, $1)}' /etc/passwd
Line:1 Fields:7 User:root
Line:2 Fields:7 User:bin
Line:3 Fields:7 User:daemon
Line:4 Fields:7 User:adm
Line:5 Fields:7 User:lp
Line:6 Fields:7 User:sync
Line:7 Fields:7 User:shutdown
打印用户id大于100的行号和用户名,其他用户不打印,输出hello
-> # awk -F ':' '{
> if ($3 > 100) {
> printf("Line:%s Fields:%s User:%s UID:%s\n", NR, NF, $1, $3)
> } else {
> print "hello"
> }
> }' /etc/passwd
找出服务器访问日志中,出现Error的时间
-> # sed -n '/Error/ p' access_log | awk '{print $1}'
-> # awk '/Error/ {print $1}' access_log
逻辑判断式
注意,逻辑判断式是在{ awk命令 }前面的
~,!~ 是否匹配正则表达式,后面跟一个正则表达式
-> # #查询主机中,用户名包含'g'的用户,打印出用户名和UID
-> # awk -F ':' '$1 ~ /g/ {print "User:"$1 "\t" "UID:"$3}' /etc/passwd
User:games UID:12
User:libstoragemgmt UID:998
User:syslog UID:996
User:yingjie UID:1005 -> # #查询主机中,用户名不包含'g'的用户,打印出用户名和UID
-> # awk -F ':' '$1 !~ /g/ {print "User:"$1 "\t" "UID:"$3}' /etc/passwd
==,!= , >=,<=,<,> ,||,&& 用于判断大小、是否相等、逻辑关系
-> # #打印分数高于70,或者低于或者等于60的记录
-> # awk '$5 > 70 || $5 < 60 {print $0}' data.txt
小红 female 一年级 BeiJing 90 Yes
小花 female 一年级 ShangHai 55
小明 male 三年级 BeiJing 90
小林 male 一年级 ChongQing 90 Yes
小波 male 一年级 HangZhou 90 No
小冰 female 五年级 BeiJing 90
扩展格式
$ awk [options] 'command' file
扩展格式是指,command扩展,格式如下:
BEGIN { command1 } pattern { awk命令 } END { command2 }
其中 BEGIN中的command1,会在读入第一行之前执行,并且只执行一次。接着循环执行中间的awk命令、
然后END后面的command2,会在文件所有行都读完之后,并执行一次command2。
-> # awk 'BEGIN {print "start"} /female/ {print $0} END {print "end"}' data.txt
start
小红 female 一年级 BeiJing 90 Yes
小花 female 一年级 ShangHai 55
小可 female 一年级 ChongQing 70
小冰 female 五年级 BeiJing 90
end
BEGIN和END
一般在BEGIN中可以做一下事情:
1、定义分隔符
2、定义表头
自定义分割符、输出时使用的分隔符
FS (fields separator)
OFS( output fields separator)
-> # awk 'BEGIN{FS=" ";OFS="-"}{print $2,$1}' data.txt
female-小红
female-小花
male-小明
female-小可
male-小林
male-小飞
male-小波
male-小康
male-小雷
female-小冰
定义表头
-> # awk '
> BEGIN {print "Name" "\t" "Gender" "\t" "Grade" "\t" "Addr" "\t" "Score" "\t" "VIP"}
> NF == 6 {print $0}
> END {print "----------end-----------"}' data.txt
Name Gender Grade Addr Score VIP
小红 female 一年级 BeiJing 90 Yes
小林 male 一年级 ChongQing 90 Yes
小波 male 一年级 HangZhou 90 No
小康 male 四年级 ShenZhen 65 No
----------end-----------
统计当前文件夹下,文件总大小
[root@VM_0_8_centos test]# ls -l
total 8
-rw-r--r-- 1 root root 367 Sep 16 11:51 data.txt
-rw-r--r-- 1 root root 1803 Aug 17 00:14 test.cpp
[root@VM_0_8_centos test]# ls -l | awk 'BEGIN {size=0} {size+=$5} END {print "Size is " size}'
Size is 2170
统计文件中非空行的行数
[root@VM_0_8_centos test]# cat demo.txt
11111 22222 33333
44444
[root@VM_0_8_centos test]# awk 'BEGIN {count=0} $0 !~ /^$/ {count += 1} END {print "Not empty line count " count}' demo.txt
Not empty line count 4
统计女生的数量
-> # awk '
> BEGIN {count = 0}
> {
> if ($2 == "female") {
> name[count++] = $1
> }
> }
> END {
> print "tot " count
> for (i = 0; i < count; i++) {
> print name[i]
> }
> }' data.txt
tot 4
小红
小花
小可
小冰
Linux awk使用方法~~整理的更多相关文章
- klia linux tools 使用方法整理
第一部分 信息收集工具 1.Zenmap 和nmap 作用是一样的,只是使用的操作方式不一样, Zenmap使用 的GUI,nmap 是基于命令行的.在两个使用的命令是一样的. 使用SYN扫描 就 ...
- Linux awk命令常见使用方法介绍
Linux awk命令常见使用方法介绍 By:授客 QQ:1033553122 awk运行方式有三种,其中常用的为命令行方式 awk [-F field_separator] '{patter ...
- linux 常用命令--------雪松整理
linux 常用命令--------雪松整理 博客: http://hi.baidu.com/quanzhou722/blog错误在所难免,还望指正!========================= ...
- linux awk命令详解
linux awk命令详解 简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分 ...
- Kali Linux渗透基础知识整理(四):维持访问
Kali Linux渗透基础知识整理系列文章回顾 维持访问 在获得了目标系统的访问权之后,攻击者需要进一步维持这一访问权限.使用木马程序.后门程序和rootkit来达到这一目的.维持访问是一种艺术形式 ...
- Kali Linux渗透基础知识整理(二)漏洞扫描
Kali Linux渗透基础知识整理系列文章回顾 漏洞扫描 网络流量 Nmap Hping3 Nessus whatweb DirBuster joomscan WPScan 网络流量 网络流量就是网 ...
- Linux进程管理知识整理
Linux进程管理知识整理 1.进程有哪些状态?什么是进程的可中断等待状态?进程退出后为什么要等待调度器删除其task_struct结构?进程的退出状态有哪些? TASK_RUNNING(可运行状态) ...
- linux awk浅析(转)
Awk 是一种非常好的语言,同时有一个非常奇怪的名称.在本系列(共三篇文章)的第一篇文章中,Daniel Robbins 将使您迅速掌握 awk 编程技巧.随着本系列的进展,将讨论更高级的主题,最后将 ...
- linux 服务器常用命令整理
linux 服务器常用命令整理 目录 网络分析 - tcpdump \ telnet \ (netstat \ ss \ lsof) \ nload 网络传输 - scp \ rsync \ (rz ...
随机推荐
- Thinkphp框架中自定义修改success和error页面
Thinkphp框架中自定义修改success和error页面 Thinkphp框架的默认success和error太难看,可以自定义设置,步骤如下: (注意:TP原框架中的success跳转有问题, ...
- Hibernate 5 入门指南-基于映射文件
由于Hibernate 4版本混乱,Hibernate 3有些过时,Hibernate 5的开发文档尚不完善,所以构建一份简单的Hibernate 5的入门指南 注:案例参考Hibernate 官方参 ...
- 详解PHP中的过滤器(Filter)
PHP 过滤器用于验证和过滤来自非安全来源的数据,比如用户的输入. 什么是 PHP 过滤器? PHP 过滤器用于验证和过滤来自非安全来源的数据. 验证和过滤用户输入或自定义数据是任何 Web 应用程序 ...
- SudokuGame 记软工第二次作业
整体概况 1.描述编写整体程序正确过程(含关键代码) 2.整体心路历程及新知分析 3.效能分析.构建之法及整体耗时时间表 4.一些心得体会 GitHub 链接如下: 1.[基础作业BIN文件(最新版) ...
- 修改mysql默认端口
最初,我将mysql端口改成了3307,现在需要将其改3306端口,已改好,做个记录 首先:借助资源监视器,找到对应的端口,查看对应的Pid,然后打开任务管理器,点击服务,找到对应的服务器,将其服务停 ...
- centos7下kubernetes(8.kubernetes Failover)
上一节我们运行的3个容器 其中有两个是运行在node2上一个运行在node1上,现在我们关闭node1,观察node1上的容器会发生什么变化 目前node1已经处于notready状态 现在我们查看一 ...
- UVA1601-The Morning after Halloween(双向BFS)
Problem UVA1601-The Morning after Halloween Accept: 289 Submit: 3136 Time Limit: 12000 mSec Problem ...
- java 在实例化异常的时候做的事情
new Exception 这段代码,会调用父类ThrowAble的构建方法,在构造方法中会调用fillInstackTrace这个native方法. 会把当前线程异常发生的信息,上下文记录在栈调用指 ...
- Java 执行远程主机shell命令代码
pom文件: <dependency> <groupId>org.jvnet.hudson</groupId> <artifactId>ganymed- ...
- JVM-Java内存区域
JVM虚拟机运行时数据区结构分为: 其中方法区和堆是所有线程共享的内存区域,而Java栈.本地方法栈.程序计数器是线程私有的. 我们详细介绍运行时数据区的各个区域及其作用. 程序计数器: 一块较小的内 ...