美文网首页
轻松掌握 Linux 文本处理三剑客:grep、awk 和 se

轻松掌握 Linux 文本处理三剑客:grep、awk 和 se

作者: 霍格沃兹测试学院 | 来源:发表于2020-12-09 14:35 被阅读0次

为什么要学习 Shell 脚本语言?

现代的互联网架构底层系统几乎都是基于 Linux 操作系统构建的,Linux 的核心价值在于提供了强大的系统内核功能进行文件管理和信息交互管理。

而 Shell 则是软件研发人员高效控制和使用 Linux 的工具和桥梁。Shell 本身是 C 语言编写的系统软件,通常也叫命令行工具。它具有一个基础的界面,用户在这个界面通过 Shell 脚本语言(Shell Script)来访问 Linux 操作系统内核服务。

Tips:尽管通常我们把「Shell」和「Shell 脚本语言」都叫做 “Shell”,但其实这两者是有本质区别的。

在科幻电影里,我们经常看到在暗色调的屏幕上 Shell 脚本代码在快速滚动,这简直成为了 Geek/Hacker 的一个形象标签。而实际工作中,Shell 也备受开发、运维、测试人员甚至运营人员的青睐,几乎是 IT 技术人员的必备技能。在软件测试技术领域,Shell 脚本编程更是自动化测试技术的基石,是测试开发工程师的必备技能。

Shell 脚本语言编程有哪些优势呢?

Shell 脚本语言的优势在于能够以最轻量级最快捷的速度处理 Linux 操作系统偏底层的业务。比如软件的自动化安装、更新版本,监控报警,日志分析等。虽然其他高级编程语言如 PHP、Python、Ruby 等语言也能做到,但是效率和开发成本上会大打折扣,所谓“杀鸡用牛刀”,有点得不偿失。

成熟的技术人会摒弃华而不实的方法,而会根据不同的场景选择最合适的工具去解决问题,朴实而高效。比如本文着重介绍的 Linux 三剑客:grep、awk 和 sed 就是 Linux 文本处理问题的最高效工具。

下面,我们将依次介绍 Linux 文本处理三剑客的基础语法,使用场景和特性,以及给出对应的实战演练题目。

Shell 编程环境安装

  • Windows 用户,建议安装 Git Bash 软件。

  • Mac 用户,建议安装 iterm2 软件。

  • ssh 工具

  • 霍格沃兹测试学院的学员可以用自己的帐号登录
    ssh 手机号码后8位@shell.testing-studio.com

  • 没有 ssh 账号的可以临时用
    ssh hogwarts2019@shell.testing-studio.com

  • 演练文档:http://testerhome.com/tmp/nginx.log 保存了一份一天的 Nginx 访问 log。

Linux 三剑客介绍

image image
  • grep:主要用于文本内容查找,支持正则表达式。
  • awk:主要用于文本内容的分析处理,也常用于处理数据,生成报告,非常适用于需要按列处理的数据。(现在很多Linux使用gawk)
  • sed:全称为 Stream editor ,主要用于文本内容的编辑,默认只处理模式空间,不改变原数据,而且 sed 使用逐行读取的方式处理数据。

grep

image image

grep 示例 Shell 脚本代码

ps -ef  | grep bash
echo "ABC" | grep -i  abc
ps -ef | grep bash | grep -v grep
echo "1234 7654" | grep -o "[0-9]4"  
echo "1234 7654" | grep -oE "[0-9]4|76"

grep 实战演练题目

  • 找出 nginx.log 中所有 404 和 503 报错的 log 数据,取出前 3 条数据,把命令贴到回复里。
  • 找出 testerhome 首页的所有 http 和 https 的链接。

awk

image image image

awk 示例 Shell 脚本代码

ps | awk 'BEGIN{print "start"}{print $0}END{print "end"}'
awk '/ 404 | 500 /' /tmp/nginx.log
echo '1
2
3
4
5' | awk '/2/,/4/'
echo '1
2
3
4
5' | awk '$0>3'
ps | awk 'NR>1'
ps | awk '{print $NF}'
echo $PATH | awk 'BEGIN{RS=":"}{print $0}' | grep -v "^$" | awk 'BEGIN{FS="\n";ORS=":"}{print $0}END{printf "\n" }'
echo '1,10
2,20
3,30' | awk 'BEGIN{a=0;FS=","}{a+=$2}END{print a,a/NR}'
awk 'BEGIN{print 33*20*76/200/3}'
echo "123|456_789" | awk 'BEGIN{FS="\\||_"}{print $2}'
echo "123|456_789" | awk "BEGIN{FS=\"\\\\||_\"}{print \$2}" #尽量使用单引号

awk 实战演练题目

  • 找出 404 和 500 的数据,只打印状态码这一列,然后排序去重。把命令贴到回复里
  • 去 testerhome 首页找到所有的 http 的连接,然后打印不带 http 的纯域名部分

sed

image

pattern表达式

  • 20 30,35 行数与行数范围
  • /pattern/ 正则匹配
  • //,// 正则匹配的区间

action

  • d 删除
  • p 打印,通畅结合-n参数
  • s/REGEXP/REPLACEMENT/[FLAGS]
  • 替换时引用 \1 \2 匹配的字段

sed 示例 Shell 脚本代码

ps | sed -n 1,3p
ps | sed 's/CMD/command/'
ps | sed -n '/ps/p'
echo '1
2
3
4
5' | sed -n '/3/,/4/p'
echo '1
2
3
4
5' | sed '/3/,/4/d'
ps | sed -e 's/CMD/command/' -e 's#00#20#g'

sed 实战演练题目

相关文章

  • awk

    awk的简介和功能 awk: Linux 文本处理三剑客:grep、sed和awk。其中grep是一种文本过滤工具...

  • grep常用选项

    grep是Linux中最常用的文本处理工具之一,与sed,awk合称Linux中的三剑客。grep的全称是:Glo...

  • Linux系统中awk和sed有什么区别?

    Linux文本三剑客,即awk、grep、sed,这三个命令是Linux中常用的文本处理命令,主要作用是对文本内容...

  • 简谈linux文本处理-sed

    文本处理能力是Linux强大优势之一,其中grep,sed和awk被称为Linux文本处理三板斧。grep 主要配...

  • 轻松掌握 Linux 文本处理三剑客:grep、awk 和 se

    为什么要学习 Shell 脚本语言? 现代的互联网架构底层系统几乎都是基于 Linux 操作系统构建的,Linux...

  • sed介绍

    sed是什么 sed是linux文本处理工具三剑客(grep,sed,awk)之一,用来处理文本的流编辑工具。主要...

  • Linux 文本处理三剑客:grep、sed 和 awk

    [TOC] awk、grep、sed是linux操作文本的三大利器,合称文本三剑客,也是必须掌握的linux命令之...

  • Grep

    Linux文本处理三剑客 grep:文本过滤(模式:pattern)工具grep, egrep, fgrep(不支...

  • AWK

    Linux文本处理工具三剑客: grep:文本过滤器 sed:流编辑器 awk:报告生成器(格式化以后,显示) a...

  • Linux-grep、sed、awk之awk命令

    参考:Linux三剑客(grep sed awk) 之 awk[https://www.jianshu.com/p...

网友评论

      本文标题:轻松掌握 Linux 文本处理三剑客:grep、awk 和 se

      本文链接:https://www.haomeiwen.com/subject/bsehgktx.html