Linux三剑客(grep、sed、awk)

下面所说的是Linux中最重要的三个命令在业界被称为“三剑客”,它们是awk,sed,grep。我们现在知道Linux下一切皆文件,对Linux的操作就是对文件的处理,那么怎么能更好的处理文件呢?这就要用到我们上面的三剑客命令。在说这三个命令前我们要插入一个小插曲就是“正则表达式”。一、正则表达式所谓的正则表达式我个人理解就是正规的表示方法。他是用简…

大家好,又见面了,我是你们的朋友全栈君。

    下面所说的是Linux中最重要的三个命令在业界被称为“三剑客”,它们是awk,sed,grep。

    我们现在知道Linux下一切皆文件,对Linux的操作就是对文件的处理,那么怎么能更好的处理文件呢?这就要用到我们上面的三剑客命令。

    在说这三个命令前我们要插入一个小插曲就是“正则表达式”。

一、正则表达式

    所谓的正则表达式我个人理解就是正规的表示方法。他是用简单的方法来实现强大的功能,所以深受计算机爱好者的使用。

    三剑客与正则表达式是什么关系呢?

    我们可以这样理解,三剑客就是普通的命令,有的把他们叫做工具,在我看来都一样。而正则表达式就好比一个模版。三剑客能读懂这个模版。就这么简单。注意只有三剑客才能读懂这个模版哦!

    现在他们的关系和功能都搞懂了,接下来我们就来认识下他们怎么结合的。正则表达式是一个模版,这个模版是由一些普通字符和一些元字符组成。普通字符包括大小写的字母和数字,而元字符则具有特殊的含义。具体如下

元字符

功能

意思

^

匹配行首

表示以某个字符开头

   $

匹配行尾

表示以某个字符结尾

  ^$

空行的意思

表示空行的意思

   .

匹配任意单个字符

表示任意一个字符

*

字符*   匹配0或多个此字符

表示重复的任意多个字符

   \

屏蔽一个元字符的特殊含义

表示去掉有意义的元字符的含义

[]

匹配中括号内的字符

表示过滤括号内的字符

.*

代表任意多个字符

就是代表任意多个字符

lele\{n\}

用来匹配前面lele出现次数。n为次数

就是统计前面lele出现的次数

lele\{n,\}

含义同上,但次数最少为n

从功能就可以看出

lele\{n,m\}

义同上,但lele出现次数在nm之间

从功能也可以看出

lele\{n,m\}

义同上,但lele出现次数在nm之间

从功能也可以看出

三剑客的功能非常强大,但我们只需要掌握他们分别擅长的领域即可:grep擅长查找功能,sed擅长取行和替换。awk擅长取列。

二、grep

文本过滤(模式:pattern)工具,grep, egrep

grep [OPTIONS] PATTERN [FILE...]

  • --color=auto 对匹配到的文本着色显示
  • -v 显示不被pattern匹配到的行
  • -i 忽略字符大小写
  • -n 显示匹配的行号
  • -c 统计匹配的行数
  • -o 仅显示匹配到的字符串
  • -q 静默模式,不输出任何信息
  • -A # after, 后#行
  • -B # before, 前#行
  • -C # context, 前后各#行
  • -e 实现多个选项间的逻辑or关系
    grep –e ‘cat ’ -e ‘dog’ file
  • -w 匹配整个单词
  • -E 使用ERE,相当于egrep
  • -F 相当于fgrep,不支持正则表达式

举例子:

1、查找文件内容包含root的行数

Linux三剑客(grep、sed、awk)

2、查找文件内容不包含root的行

Linux三剑客(grep、sed、awk)

3、查找以s开头的行

Linux三剑客(grep、sed、awk)

4、查找以n结尾的行

Linux三剑客(grep、sed、awk)

三、sed

sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。然后读入下行,执行下一个循环。如果没有使诸如‘D’ 的特殊命令,那会在两个循环之间清空模式空间,但不会清空保留空间。这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。

sed [option]... 'script' inputfile

  1. 选项
    • -n 不输出模式空间内容到屏幕,即不自动打印
    • -e 多点编辑
    • -f /PATH/SCRIPT_FILE: 从指定文件中读取编辑脚本
    • -r 支持使用扩展正则表达式
    • -i 直接编辑文件
    • -i.bak 备份文件并原处编辑
  2. script 地址定界
    1. 不给地址:对全文进行处理
    2. 单地址:
      #: 指定的行,$:最后一行
      /pattern/:被此处模式所能够匹配到的每一行
    3. 地址范围:
      #,#
      #,+#
      /pat1/,/pat2/
      `#,/pat1/
    4. ~:步进
      1~2 奇数行
      2~2 偶数行
  3. 编辑命令:
    • d 删除模式空间匹配的行,并立即启用下一轮循环
    • p 打印当前模式空间内容,追加到默认输出之后
    • a [\]text1 在指定行后面追加文本,支持使用\n实现多行追加
    • i [\]text 在行前面插入文本
    • c [\]text 替换行为单行或多行文本
    • w /path/somefile 保存模式匹配的行至指定文件
    • r /path/somefile 读取指定文件的文本至模式空间中匹配到的行后
    • = 为模式空间中的行打印行号
    • ! 模式空间中匹配行取反处理
    • s///:查找替换,支持使用其它分隔符,s@@@,s###
      替换标记:
      • g 行内全局替换
      • p 显示替换成功的行
      • w /PATH/TO/SOMEFILE 将替换成功的行保存至文件中

举例子:

1、打印出文件第二行

Linux三剑客(grep、sed、awk)

2、打印出2-5行的内容

Linux三剑客(grep、sed、awk)

3、将文件中的root全部替换为abc

Linux三剑客(grep、sed、awk)

直接修改读取的文件内容,而不是输出到终端。
s :取代,可以直接进行取代的工作。

g: 是全局的意思。其中#是格式符,他也可以是@或者别的/。

Sed替换格式是:sed -i ‘s/要替换的内容/替换成的内容/g’ 文件名。

四、awk

报告生成器,格式化文本输出,有多种版本:New awk(nawk),GNU awk( gawk)

awk [options] 'program' file…

  1. program:pattern{action statements;..}
    1. pattern部分决定动作语句何时触发及触发事件
      BEGIN,END
    2. action statements对数据进行处理,放在{}内指明
      print, printf
  2. 选项:
    -F 指明输入时用到的字段分隔符
    -v var=value 自定义变量
  3. 分割符、域和记录
    awk执行时,由分隔符分隔的字段(域)标记1,1,2..n称为域标识,n称为域标识,0为所有域。
    省略action,则默认执行 print $0 的操作。
  4. 变量
    FS:输入字段分隔符;OFS:输出字段分隔符;RS:输入记录分隔符;ORS:输出记录分隔符;NF:字段数量;NR:记录号;NFR:各文件分别计数,记录号。FILENAME:当前文件名;ARGC:命令行的参数;ARGV:数组,保存的是命令行所给定的各参数。

    注意:以上都是内置变量,在引用时不需要前面加$,每新建一个变量,都需要加个-v,与变量名之间有无空格都可以,变量可以在引用之后再声明,但那一行的输出会输出空行。

  5. printf命令
    printf “FORMAT” , item1, item2, ... 不会自动换行,FORMAT中需要分别为后面每个item指定格式符。

    • 格式符
    格式符 item表现形式
    %c 显示字符的ASCII码
    %d, %i 显示十进制整数
    %e, %E 显示科学计数法数值
    %f 显示为浮点数
    %g, %G 以科学计数法或浮点形式显示数值
    %s 显示字符串
    %u 无符号整数
    %% 显示%自身
    • 修饰符
    格式符 item表现形式
    #[.#] 第一个数字控制显示的宽度;第二个#表示小数点后精度,%3.1f
    左对齐(默认右对齐) %-15s
    + 显示数值的正负符号 %+d
  6. 操作符

    • 算术操作符:x+y, x-y, x*y, x/y, x^y, x%y
      -x: 转换为负数
      +x: 转换为数值
    • 比较操作符:==, !=, >, >=, <, <=
    • 模式匹配符:~:左边是否和右边匹配包含 !~:是否不匹配
    • 逻辑操作符:与&&,或||,非!
    • 函数调用:function_name(argu1, argu2, ...)
    • 条件表达式(三目表达式):selector?if-true-expression:if-false-expression
  7. PATTERN:根据pattern条件,过滤匹配的行,再做处理
    1. 如果未指定:空模式,匹配每一行
    2. /regular expression/:仅处理能够模式匹配到的行,需要用/ /括起来
    3. relational expression: 关系表达式,结果为“真”才会被处理
    4. line ranges:行范围 startline,endline:/pat1/,/pat2/不支持直接给出数字格式
    5. BEGIN/END模式
  8. awk控制语句
    • { statements;… } 组合语句
    • if(condition) {statements;…}
    • if(condition) {statements;…} else {statements;…}
    • while(conditon) {statments;…}
    • do {statements;…} while(condition)
    • for(expr1;expr2;expr3) {statements;…}
    • break
    • continue
    • delete array[index]
    • delete array
    • exit

awk [-F|-v] '行数筛选{XXX;XXX;printf “”,XXX,XXX}'

举例子:

1、打印文件第一列:

Linux三剑客(grep、sed、awk)

这里的分隔符是冒号 ,然后print打印第一列

2、输出字段1,3,6,以制表符作为分隔符

Linux三剑客(grep、sed、awk)

 

 

awk详解:https://www.cnblogs.com/xudong-bupt/p/3721210.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/125066.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • linux双网卡架设FTP,LINUX系统上架设FTP服务器[通俗易懂]

    linux双网卡架设FTP,LINUX系统上架设FTP服务器[通俗易懂]CentOS上搭建FTP服务器服务器软件:vsftpd简要说明:vsftpd是linux下的一款小巧轻快,安全易用的FTP服务器软件,是一款在各个LINUX发行版中最受推崇的FTP服务器软件。至于它的安装教程,网络上也是数不胜数,每个教程都有各自的优缺点,祥哥特意做了个总结,取别人之长处,尽量做到菜鸟级别的教程。当你看见祥哥的这篇文章,能更好的使用和运用VSFTPD。下面正题开始。安装vsftpd…

  • Google Buzz掀起新一轮隐私权争议「建议收藏」

    Google Buzz掀起新一轮隐私权争议「建议收藏」Google本周开始于全球的Gmail帐号中部署GoogleBuzz社交服务,不过,新上线的GoogleBuzz旋即引来外界对其隐私政策的质疑。GoogleBuzz可整合状态更新、连结、照片及影片等社交分享功能,移动版还加上了位置分享功能。引起隐私争议的其中一项功能为GoogleBuzz可自动找出使用者在Gmail中最常联系的好友并产生追随/被追随名单,而且使用者追随/被追随的对象列…

    2022年10月15日
  • PriorityQueue的用法和底层实现原理

    PriorityQueue的用法和底层实现原理先讲使用,再讲原理队列是遵循先进先出(First-In-First-Out)模式的,但有时需要在队列中基于优先级处理对象。举两个例子:作业系统中的调度程序,当一个作业完成后,需要在所有等待调度的作业中选择一个优先级最高的作业来执行,并且也可以添加一个新的作业到作业的优先队列中。 每日交易时段生成股票报告的应用程序中,需要处理大量数据并且花费很多处理时间。客户向这个应用程序发送请求时,…

  • 适配器及其作用[通俗易懂]

    适配器及其作用[通俗易懂]1.适配器适配器是一个接口转换器,它可以是一个独立的硬件接口设备,允许硬件或电子接口与其它硬件或电子接口相连,也可以是信息接口。但是现在的计算机主板上就已经嵌入了适配器,因此现在的计算机上的适配器不是独立的。2.适配器的作用1.要进行数据串行传输和并行传输的转换。2.对数据进行缓存。3.实现以太网协议。4.管理该适配器的设备驱动程序安装在计算机的操作系统。…

  • SpringBoot入门系列HelloWorld

    SpringBoot入门系列HelloWorld

  • cdn加速配置_自己配置cdn

    cdn加速配置_自己配置cdn配置方法同上篇文章一样CDN加速配置,阿里云cdn内配置好以后即可剩下把前端服务器nginx内的证书文件上传以及配置写好即可。后端服务器也同上配置证书下载上传服务器配置好nginx即可。如果都配置好以后,不可以访问时,注意查看前端请求接口是否为https方式。如果为http时,检查是否更新服务器成功,如果成功后还不可以正常访问时,前端修改代码如下:vue.config.js内添加下行代码。index.html下添加代码:https:true完毕!…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号