Linux三剑客(grep+awk+sed)

一、grep

 grep pattern file 

grep -i pattern file 忽略⼤⼩写 

grep -v pattern file 不显⽰匹配的⾏ 

grep -o pattern file 把每个匹配的内容⽤独⽴的⾏显⽰ 

 grep -E pattern file 使⽤扩展正则表达式 

 grep -A -B -C pattern file 打印命中数据的上下⽂ 

 grep pattern -r dir/ 递归搜索

二、BRE基本正则表达式

^ 开头 $结尾 

[a-z]  [0-9] 区间,如果开头带有^表⽰不能匹配区间内的元素 

 * 0个或多个 

 . 表⽰任意字符

三、ERE扩展正则表达式

基本正则表达式(BRE)基础上的扩展 

? ⾮贪婪匹配 

+  ⼀个或者多个 

() 分组 

{} 范围约束 

| 匹配多个表达式的任何⼀个

四、awk

1、介绍 

    Awk是linux下的⼀个命令,同时也是⼀种语⾔解析引擎 

    Awk具备完整的编程特性。⽐如执⾏命令,⽹络请求等 

    精通awk,是⼀个linux⼯作者的必备技能 

2、awk pattern语法( awk 'pattern{action}')

    awk理论上可以代替grep 

    awk 'pattern{action}'

    awk 'BEGIN{}END{}'  开始和结束 

    awk '/Running/'  正则匹配 

    awk '/aa/,/bb/' 区间选择 

    awk '$2~/xxx/' 字段匹配 

    awk 'NR==2' 取第⼆⾏ 

    awk 'NR>1'  去掉第⼀⾏

3、awk内置变量

    FS 字段分隔符 

    OFS 输出数据的字段分隔符 

    RS 记录分隔符 

    ORS 输出字段的⾏分隔符 

    NF 字段数 

    NR 记录数

4、awk的字段数据处理

    -F 参数指定字段分隔符 

    BEGIN{FS="_"} 也可以表⽰分隔符 

    $0代表当前的记录 

    $1代表第⼀个字段 

    $N 代表第N个字段 

    $NF 代表最后⼀个字段 

    $(NF-1) 代表倒数第⼆个字段

5、awk字段分割

    echo $PATH | awk 'BEGIN{RS=":"}{print $0}' \ 

    | awk -F/ '{print $1,$2,$3,$4}' 

    echo $PATH | awk 'BEGIN{RS=":"}{print $0}' \ 

    | awk 'BEGIN{FS="/"}{print $1,$2,$3,$4}' 

    echo $PATH | awk 'BEGIN{RS=":"}{print $0}' \

    | awk 'BEGIN{FS="/|-"}{print $1,$2,$3,$4}'

    修改OFS和ORS让$0重新计算 

    echo $PATH | awk 'BEGIN{FS=":";OFS=" | "}{$1=$1;print $0}' 

    echo $PATH | awk 'BEGIN{RS=":";ORS="^"}{print $0}'

6、awk⾏处理

    把单⾏分拆为多⾏

    echo $PATH | awk 'BEGIN{RS=":"}{print $0}'

    echo $PATH | awk 'BEGIN{RS=":"}{print NR,$0}'

    echo $PATH | awk 'BEGIN{RS=":"}END{print NR}'

    多⾏组合为单⾏

    echo $PATH | awk 'BEGIN{RS=":"}{print $0}' |

    awk 'BEGIN{ORS=":"}{print $0}'

7、数据计算

    echo '1,10

    2,20

    3,30' | awk 'BEGIN{a=0;FS=","}{a+=$2}END{print a/NR}'

8、awk的词典结构

五、sed

   sed [addr]X[options]

   -e 表达式

   sed -n '2p' 打印第⼆⾏

   sed 's#hello#world#' 修改

   -i 直接修改源⽂件

   -E 扩展表达式

   --debug 调试

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux三剑客指的是 awksedgrepawk 是一种用来处理文本文件的工具,它可以根据指定的模式进行自动分割并进行数据处理。 sed 是一种流编辑器,它可以对文本文件进行替换、删除和插入操作。 grep 是一种文本搜索工具,它可以在文本文件中搜索指定的字符串。 ### 回答2: Linux三剑客,分别是awksedgrep,它们是Linux系统中非常重要的命令行工具,它们通常被称为文本处理工具。这些工具通常被用于筛选、搜索和处理文本文件。 grep是一种常见的文本搜索工具,可以在文件和文件夹中搜索指定的字符串或正则表达式。grep可以搜索多个文件并返回匹配行的输出。它是处理日志文件或查找匹配模式的最佳工具之一。 sed是一种流编辑器,可以按照行处理文本文件。它可以通过替换、删除和插入操作来修改文件内容。在大型文件中查找并替换模式是sed的主要作用。该工具通常在文本文件中提取有用信息是常用。 awk是一种强大的文本操作工具,可以分析大型文本文件并对其进行处理。该工具可以遍历行和列,并提供强大的文本处理工具,如计算、过滤和转换数据。awk的处理速度非常快,适用于处理大型数据文件。 Linux三剑客awk是最强大的工具,它可以执行复杂的文本数据操作和转换,可大大简化开发和管理过程。sed主要用于简单的文本数据过滤和替换,而grep主要用于搜索文件和定位特定行。 总之,Linux三剑客在文本数据处理方面具有不可替代的重要作用。对于Linux操作系统的开发人员和管理员来说,熟练使用这些工具可以提高他们的工作效率,使他们更容易管理和操作文本文件。 ### 回答3: Linux三剑客awk sed grep是我们在日常工作中经常使用的三个命令。它们都属于文本处理工具,可以用于查找、处理、分析文本文件等。 首先,grep是最常用的文本搜索工具。grep可以用来快速查找文件中指定的字符串或正则表达式,并将包含该字符串或正则表达式的行打印出来。常用的命令有grep、egrep和fgrep。比如,我们可以使用grep命令来查找一个文件中包含指定关键字的行,可以使用egrep来支持正则表达式搜索,使用fgrep来进行快速搜索,不支持正则表达式。 其次,sed是一种流编辑器,主要用于对文本文件进行替换、删除、添加、插入等操作。sed命令可以通过管道(|)将多个命令组合起来,从而进行复杂的文本操作。sed可以快速完成对文本文件的修改操作,比如替换文件中的某些内容、删除特定的行、在文件中插入新的文本等。sed的命令形式是“command", 比如"s/old/new/g",表示将old替换成new。 最后,awk是一种强大的文本处理工具,主要用于在文本文件中查找、处理以及格式化特定的字段。和grepsed不同的是,awk更加灵活,可以在处理过程中做到数据过滤和加工,对于大数据的处理特别有用。awk命令的常用语法是"pattern {action}"。其中,pattern代表要匹配的模式,而action代表模式匹配时需要执行的动作,我们可以在其中添加处理语句来对文件进行各种处理操作,比如计算、统计、格式化等。 综上所述,Linux三剑客awk sed grep是我们在文本处理工作中不可或缺的三个工具,不同的工具可以用于处理不同的文本操作,也可以用于搭配使用,以完成更加复杂的文本处理工作。对于需要经常处理文本的人员来说,掌握这些工具是非常必要的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值