awk 的基本语法

awk 是模式查找与处理语言,是文本处理的利器。使用 awk 可以只用一条简单的命令完成复杂的文本数据处理。 awk 命令的基本结构为:

awk '模式 {处理}' 文件

比如,打印 datafile.txt 中所有包含 Female 的行:

awk '/Female/ {print $0}' datafile.txt

datafile.txt 的内容:

Bob   23   Male
Tim 18 Male
Kate 19 Female
Ann 18 Female
Jim 23 Male

输出的结果为:

Kate  19   Female
Ann 18 Female

以上命令中: /Female/ 就是一个正则表达式,awk 会一行行读取文件,如果遇到某一行与该正则表达式匹配,则执行后面的 {print $0} 操作。

awk 的常见用法

继续用上面的 datafile.txt 为内容举例如下:

# 计算所有 Male 及 Female 各多少人
awk '/Male/ {m++} /Female/ {n++} END {print "Male", m, "Female", n}' datafile.txt
# 计算 Male 的平均年龄
awk '/Male/ {m++; n+=$2} END {print n/m}' datafile.txt
# 以字符 'm' 作为分隔符分隔一行,并打印每行的第一段
awk 'BEGIN {FS="m"} // {print $1}' datafile.txt
# 以数字作为分隔符分隔一行,并打印1-3行的第一、二段,4-5行的第一段
awk 'BEGIN {FS="[[:digit:]]+"} NR<=3 {print $1,$2} NR>3 {print $1}' datafile.txt
# 打印年龄不包含数字 1 的行
awk '! /1/ {print $0}' datafile.txt
# 打印年龄为 18 的行
awk '$2 == 18 {print $0}' datafile.txt

在 linux 系统中,awk 可以通过管道处理一些数据

# 杀掉监听 10080 端口的进程
netstat -nap | awk 'BEGIN {FS="[ /]+"} /LISTEN/ && /10080/ {print $7}' | xargs kill -9
# 统计 Apache 的访问日志,各个 IP 的访问次数是多少
awk '// {m[$1]++} END {for (i in m) print i "\t" m[i]}' /etc/httpd/logs/access_log

sed 的基本语法

如果把 awk 比作文本查询语言的话,sed 就是文本修改语言。两者配合基本上可以不用打开文本文件就可以实现类似于数据库操作的增删改查工作。这一点在批量处理文件的时候非常重要。

sed 的基本结构与 awk 类似:

sed '模式 处理' 文件
sed '模式 {处理序列}' 文件

比如,以 datafile.txt 为例,将 Bob 的年龄修改为 124 岁

sed 's/\(Bob[ \t]*\?\)\([0-9]\+\)/\1124/' datafile.txt

将会显示以下的结果:

Bob   124   Male
Tim 18 Male
Kate 19 Female
Ann 18 Female
Jim 23 Male

sed 常见用法

# 打印包含数字 1 的所有行
sed -n '/1/ p' datafile.txt
# 打印所有行
sed -n 'p' datafile.txt
sed '' datafile.txt
# 将 Female 或者 Male 的首字母变为小写
sed 's/\([0-9][ \t]\+\)\(.\)/\1\l\2/' datafile.txt
sed -n '{s/\([0-9][ \t]\+\)\(.\)/\1\l\2/ p}' datafile.txt
# 将 Female 或者 Male 的前三个字母大写,后面的小写
sed 's/\([0-9][ \t]\+\)\(....\)\(.*\)/\1\U\2\L\3\E/' datafile.txt
sed -n '{s/\([0-9][ \t]\+\)\(....\)\(.*\)/\1\U\2\L\3\E/ p}' datafile.txt
# 删除奇数行,如1,3,5行
sed '1~2 d' datafile.txt
# 统计文件有多少行
sed -n '$=' datafile.txt
# 实现 head 的功能
sed '2 q' datafile.txt
# 打印每行行号
sed '=' datafile.txt
# 先找到文档中的数字行,从数字行开始删除一直删除到有空行为止
sed '/[0-9]/,/^$/ d' data

纯命令行的编辑利器:用好 awk 与 sed的更多相关文章

  1. Linux命令行下编辑常用的快捷键

    Linux命令行编辑快捷键: Ctrl+r 然后输入若干字符,开始向上搜索包含该字符的命令,继续按Ctrl+r,搜索上一条匹配的命令,按Ctrl+c或上下键退出. Ctrl+l 清屏 !num 执行命 ...

  2. 我的ubuntu连vi都没有??那在命令行怎么编辑文件??

    今天弄了个docker下的ubuntu官方镜像,想在镜像里做一点实验,免得把自己的环境写得乱七八糟. 把代码文件mount进去之后,开始编译,但是镜像太干净了,什么工具都没有,于是先装cmake ap ...

  3. mysql定时任务(数据库管理工具and 纯命令行)

    1.工具:Navicat 2.通过下列语句l爱查询event是否开启 打开Navicat命令列界面(点击工具可以看到或按F6) 输入下面命令 show variables like '%sche%'; ...

  4. shell命令行快速编辑命令

    ctrl r:命令行出现 reverse-i-search,输入字符将在输入历史中匹配命令 ctrl p:向前翻看历史 ctrl n:向后翻看历史 ctrl a:命令行首 ctrl e:命令行尾 ct ...

  5. mvn从下载安装到纯命令行创建第一个mvn程序(编码,编译,测试,安装,打包)全过程细致分解

    1.maven的下载和安装: a.maven的下载注意事项:如果你是windows,请选择①号,如果你是linux,请选择②号,下载地址:http://maven.apache.org/downloa ...

  6. ubuntu进入纯命令行

    启动按shfit 然后光标在第一行按e 倒数第二行末尾添加quiet splash $vt_handoff 3 然后按CTRL+X或F10引导系统,启动之后就是命令行模式了

  7. mysql 取消命令行继续编辑

    mysql> create database mingongge defa\c#回车 置空mysql>  加一个\c  cancel 编辑命令 回车

  8. PathMarker:命令行快速编辑跳转工具(配合git,find等)

    简介 当使用git, find等工具时,一般需要进一步打开文件或跳转目录. 通常的做法是使用鼠标复制黏贴,或者手工输入. PathMarker提供一种快速通过标号,编辑相关文件,跳转相关目录的方法,提 ...

  9. 第三篇:Linux的基本操作与文件管理(纯命令行模式下)(下)

    接上篇介绍完软件的管理(查询.删除.安装)之后,本篇将介绍Linux的文件和目录的管理. 如何浏览Linux的目录(文件夹),就像Windows一样,我们平时需要打开各个目录,去里面找一找曾经悄悄存储 ...

随机推荐

  1. NetMQ(二): 请求响应模式 Request-Reply

    ZeroMQ系列 之NetMQ 一:zeromq简介 二:NetMQ 请求响应模式 Request-Reply 三:NetMQ 发布订阅模式 Publisher-Subscriber 四:NetMQ ...

  2. Python-内置函数小结

    内建函数,Python内置的函数(build in function),不需要引用其他包,一般成为BIF   abs() 计算绝对值,abs(-10),接收number,返回一个number   ma ...

  3. 对于挑战书上的很久之前都看不懂的DP看懂的突破

    突破一..牢记问题概念 并且牢记dp状态方程 突破二..一直有一个求和dp转化成O1dp递推的式子看不懂.. 看不懂的原因是..没有分清求和符号作用的范围 提醒:以后遇到求和符号一定明确其求和的式子的 ...

  4. windows和linux之间“/”, "\\"的区别

    在windows下编程操作文件目录时,文件目录一般是如下的形式: C:\\folder1\\folder2\\folder3\\file.txt 而在Linux或者Mac系统下,文件目录则一般是这样子 ...

  5. 网络神器Greasemonkey(油猴子)使用方法简介+脚本分享【转载】

    推荐下,觉得这个方法有用, 今天艾薇百科来介绍一下功能强大的Greasemonkey,俗称"油猴子",Greasemonkey可以自由定制网页,实现你想要的各种功能.堪称" ...

  6. orcal 操作

    清空表数据(不清除表结构): truncate table 表名

  7. drawPython

    # drawSnake import turtle def drawSnake(rad,angle,len,neckrad): for i in range(len): turtle.circle(r ...

  8. 查看java源码显示source not found

    除了下载的jar包之外,还要下载src源码的zip包. 进项目的Java Build Path里找到你想看源码的jar包 Source Attachment Configuration--Extern ...

  9. Cucumber(一): Preparation

    Every time I wrote some code in ruby and executed our cucumber features I craved for something simil ...

  10. Nodemanager Out of heap memory[fix bug全过程]

    问题: 自己写了一个yarn上的application,发现nodemanager过段时间,会out of memory退出,把nodemanager的heap memory从1G增大到2G也是无法避 ...