文本编辑三巨头(grep)

目录

正则表达式

元字符

grep

案例

我在编写脚本的时候发现,三个文本编辑的命令(grep、sed、awk,被称为文本编辑三剑客,我习惯叫它三巨头)用的还挺多的,说实话我一开始学的时候也有些懵,主要是太多太杂,有那么个别些还有点难懂,最近恰好有时间,索性把三巨头相关的东西都整理出来,方便日后生疏了再回顾一下,顺便和大家一起交流学习。

在学三巨头之前,首先要知道正则表达式

正则表达式

什么是正则表达式?正则表达式又称规则表达式,通常用于判断语句中,是一种用于匹配字符串中字符组合的模式,一般由普通字符(字母、数字)与特殊字符(元字符)组成

我们之前讲过文件测试,是用 [ ]或者 test 实现的,还有学习 if 语句的时候,也是通过 [ ] 来进行条件判断。正则表达是也是用 [ ] 来做字符串匹配的,只不过,它所匹配的样式种类更多更齐全。

正则表达式直接使用的匹配规则是 

[[  变量  =~  正则式  ]]

一个例子,我们定义一个变量 num     看看它与正则式是否匹配,输出结果是匹配    

=~ 是匹配正则式的固定搭配,测试的时候不要忘了加

[0-9] 是检验变量里是否有0-9的数字

这里你可能会疑问,如果num = s2d2j93  这种数字字母穿插的,判断结果是什么呢?

答案是,仍然输出匹配, 因为 [0-9] 只看你的变量中有没有数字,我们之前在编写shell脚本的时候也遇到,一个猜数字的脚本,如何避免输入除数字外的其他字符呢?

现在可以得到解答了,只需要验证变量是否 =~ ^[0-9]+$  就可以了。

我们都知道,在grep命令中,^是以什么什么开头,而$是以什么什么结尾,这样一组合,是不是就通俗易懂了,以数字开头以数字结尾,那不就是匹配纯数字的字符串吗?

我们来正反都验证一下,结果不出我所料(doge

元字符

通过上面这个例子,想必应该对正则有了个大致的了解,其实并不困难,主要就是选项很多很杂,常见的元字符有

[ ]:定义一个字符类,匹配括号内的任意一个字符。

例如, [abc] 可以匹配 "a"、"b" 或 "c"

.:匹配除换行符之外的任何单个字符

例如, a.c 可以匹配 "abc"、"a1c"、"a@c" 等

*:匹配前面的元素零次或多次

例如, ab*c 可以匹配 "ac"、"abc"、"abbc"、"abbbc" 等

+:和 * 一样,但只能匹配前面的元素一次或多次,不包括零次

所以 ab+c 只可以匹配 "abc"、"abbc"、"abbbc" 等,不能匹配 "ac"

?:匹配前面的元素零次或一次

例如,ab?c 可以匹配 "ac" 或 "abc"

^:匹配字符串的开始。

例如, ^abc 匹配以 abc 开头的字符串。

$:匹配字符串的结束。

例如, abc$ 匹配以 abc 结尾的字符串。

[^]:定义一个否定字符类,匹配不在括号内的任意一个字符。

例如, [^abc] 匹配除了 "a"、"b" 和 "c" 之外的任意字符。

|:或操作符,匹配两者中的任意一个。

例如,正则表达式 abc|def 可以匹配 "abc" 或 "def"。

():分组,用于将多个元素组合成一个单元,并捕获匹配的文本。

例如, (abc)+ 可以匹配 "abc"、"abcabc" 等。

\{n\}:匹配前面的元素恰好 n 次。

例如, a{3} 可以匹配 "aaa"。

\{n,\}:匹配前面的元素至少 n 次。

例如, a{3,} 可以匹配 "aaa"、"aaaa"、"aaaaa" 等。

\{n,m\}:匹配前面的元素至少 n 次,但不超过 m 次。

例如, a{3,5} 可以匹配 "aaa"、"aaaa"、"aaaaa"。

\d:匹配任意一个数字字符(0-9)。

例如, \d 可以匹配 "1"、"2"、"3" 等。

\w:匹配任意一个字母、数字或下划线字符。

例如, \w 可以匹配 "a"、"1"、"_" 等。

\s:匹配任意一个空白字符(空格、制表符、换行符等)。

例如, \s 可以匹配空格、制表符等。

\D:匹配任意一个非数字字符。

例如, \D 可以匹配 "a"、"@"、" " 等。

其实还有一部分没有列出,基本上用不到,可能用到的就这么多了,万一有遗漏我后续会补上。

正则表达式的规则就这么多,大多数情况都是搭配三巨头使用的,所以说接下来就可以开始学习三巨头了,搭配 grep、sed、awk 等命令使用的时候,含义是不变的,但是使用的符号会有点出入,所以接下来就通过大量的实例来进行讲解。

grep

首先肯定是从我们最为熟知,也是使用过的 grep 命令开始,grep命令最常用的参数可能就是

grep -v 还有 grep -i 了,这两个都是它的基本选项,我们接下来要了解它的输出控制选项,所以说要和正则表达式搭配使用呢,一个负责筛选过滤,一个负责控制输出的内容。常用的有

-E :开启扩展的正则表达式

-c :计算找到 '搜寻字符串' 的次数

-o :只显示被模式匹配到的字符串

-w:匹配整个单词

-n :输出行号

我创建了一个 123.txt 文件,用来测试各种案例,你们可以直接复制粘贴使用

#123.txthis is a test file for grep command.
t contains various patterns and special characters.asic characters: abc, def, ghi
2. Digits: 123, 456, 789
3. Special characters: ., *, +, ?, ^, $, [, ], {, }, |, (, )
4. Word boundaries: start, end, middle
on-word characters: @, #, %, &, !
scaped characters: \., \*, \+, \?, \^, \$, \[, \], \{, \}, \|, \(, \)
ultiple lines with the same pattern:patternpatternpattern
Case sensitivity: Case, case, CASEWhole word matching: word, sword, reword
hole line matching: This is a whole line.
ontext lines:This is line before the match.
his is the matching line.
This is line after the match.
ile names: file1.txt, file2.txt, file3.txt
Directory names: dir1, dir2, dir3
xclude patterns: exclude this line
Include patterns: include this line
ecursive patterns:./dir1/file1.txt./dir2/file2.txt./dir3/file3.txt
olor highlighting: highlight this
ount matching lines: count this line
Matching groups: group1, group2, group3
on-matching groups: nongroup1, nongroup2, nongroup3
ll
lol
lool
loool
loooool
looooool
looooooool
loooooooooooooooooool

案例

先来个简单的吧,找出 hole 并打印行号 

grep -n 'hole' 123.txt

打印出来有两个,此时我们加一个w,就可以只显示 hole 这个单词的了

那么相反,如果我查找不含 hole 的 只需要加上 -v 就可以了,也可以通过 [^] 来筛选前面不含w的

grep -n '[^w]hole'   (还有别的方法可以自己测试,比如[^a-z]hole,直接让前面不带字母等等)

接下来需要查找 test 或者 text 并打印行号(-n 之后的例子就不特别说明了)

grep -n 'te[sx]t' 123.txt

这里用到了[ ] ,匹配 s 或 x ,test 和 text 都被输出了出来

我们也可以通过 '.' 任意字符,来完成这个操作

grep -n 'te.t' 123.txt    有几个 . 就代表中间有几个任意字符

我们再来查找一下有数字的行       

  grep -n '[0-9]' 123.txt

下面我们来查找以数字开头的行

grep -n '^[0-9]' 123.txt

以此类推,假如以字母开头,那就是 ^[a-z]

那么,现在有一个疑问,假如要查找不以字母开头的呢?要知道,除了字母数字,还有特使字符和空格等开头的行,而且字母也是有大小写的,此时该怎么办呢?

原理也差不多,[^] 是过滤不含某些内容的,那我们就不含字母

grep -n '^[^a-zA-Z]' 123.txt         这个正则表达式同时过滤了小写字母和大写字母,如果连数

                                                  字也要过滤掉,那么就在a-zA-Z的随便哪个位置加上0-9就可

                                                  以了,顺序无所谓的,但最好按照a-z A-Z 的顺序,不然不确

                                                  定会不会出现什么问题

 附上过滤数字的运行截图

如果想查找以字母或数字结尾的,那么和以什么什么为开头的一样,在 [ ] 后面加上 $ 就可以了,如图,就不细说了↓

grep '[789]$' 123.txt 过滤出来是只有9是亮着的,因为 [ ] 匹配了 7 或者 8 或者 9 的字符串,那么,问一个简单的问题,假如我就非要,查找789这一个整体结尾的行,该怎么办呢?

额外提一句,grep -n '^$' 123.txt  代表输出空行的行

接下来,测试文件里的那么多 looool ,要派上用场了

回过头来看咱前面提到的元字符,是不是突然想到了什么

grep -n 'lo*l' 123.txt              grep -n 'lo+l' 123.txt

它们的输出结果应该 *  有ll,而 + 没有,除此之外输出结果应该一致

验证一下

一个新的问题出现了,为什么  grep -n 'lo+l' 123.txt  没有任何结果输出?我仅仅是将 * 号改成了+号,按理来说不可能出现语法错误啊?

我们来排错一下, grep -v 'lo+l' 123.txt  

整个文档都被输出出来了,说明文档里没有能与 'lo+l' 匹配的行,我们试着去文档里创捷新的一行,只有lo+l

保存并退出, 再来一次 grep -n 'lo+l' 123.txt 

真相了家人们,grep过滤的时候,读取的是 “lo+l” 这一整个字符串,+ 并没有被当作是元字符,我们给它加上一个 \ 转义符看看

这下成功了,得到想要的结果了,再回过头来看,是不是和 lo*l 的输出只相差了一个 ll

现在,我只想查找,ll之间夹着 3-6 个 o 的行

 grep -n 'lo\{3,6\}l' 123.txt

其他的需求也可以依葫芦画瓢,比如 至少 5个o 那就是 grep -n 'lo\{5,\}l' 123.txt , 转义符不要忘记

grep过滤的功能远不止在过滤文件内容,还可以搭配管道符号,再写入脚本,对脚本进行很大的优化

比如我们都知道,ifconfig ens33  是查看网卡的内容

那么,我们是不是可以通过一些条件约束,使之只显示我们需要的内容呢?比如说ip地址

很简单啊,过滤inet开头那一行,但是这样的输出结果,无法直接作为纯数字传递给脚本参数等进行处理,我们需要仅显示ip地址等

那么就需要过滤含有 [0-9].[0-9].[0-9].[0-9] 的行

 ifconfig ens33 |grep -o "[0-9]\+\.[0-9]\+\.[0-9]\+\.[0-9]\+"

学好三巨头还是要靠熟记各种参数元字符的含义并巧妙应用,做到事半功倍的效果

另外还有sed 和 awk 我之后整理了差不多再进行讲解

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/874988.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity3D之TCP网络通信(客户端)

文章目录 概述TCP核心类异步机制 Unity中创建TCP客户端Unity中其它脚本获取TCP客户端接受到的数据后续改进 本文将以Unity3D应用项目作为客户端去连接制定的服务器为例进行相关说明。 Unity官网参考资料: https://developer.unity.cn/projects/6572ea1bedbc2a001ef…

2024年平面设计软件:六大选择

无论是与营销还是产品设计,平面设计都是当今各个行业不可或缺的一部分。然而,随着平面设计软件的范围和复杂性的不断扩展,设计师和业余用户可能更难知道哪些工具最能满足他们的需求。 本文将分析当今流行的分析 6 个平面设计 App&#xff0c…

mac清理软件哪个好用免费 MacBook电脑清理软件推荐 怎么清理mac

随着使用时间的增长,mac电脑会积累一些不必要的垃圾文件,这些文件会占用宝贵的存储空间,影响电脑的运行速度和稳定性。因此,定期清理mac电脑的垃圾文件是非常有必要的。市场上有许多优秀的Mac清理软件,包括一些出色的国…

AI产品经理怎样入门?

AI产品经理需要熟悉AI基础知识,包括AI行业现状,数学统计学,AI模型构建和模型基本概念。 之所以需要具备这些知识,是因为实现AI产品必然会涉及相应的AI技术,如果AI产品经理不了解相应技术基础,就不能很好的…

photoshop学习笔记——移动工具

移动工具,可以对图层进行移动,快捷键 V 使用的素材已经放上了,直接下载即可 按住ctrl 可以自动选取,鼠标点击哪个对象,自动选中哪个图层 按住 shift 校正角度(只能沿着直线移动) 按住 alt 拖…

llama模型,nano

目录 llama模型 Llama模型性能评测 nano模型是什么 Gemini Nano模型 参数量 MMLU、GPQA、HumanEval 1. MMLU(Massive Multi-task Language Understanding) 2. GPQA(Grade School Physics Question Answering) 3. HumanEval llama模型 Large Language Model AI Ll…

网络七层协议之 网桥、网卡、交换机、路由器、网关 作用

OSI七层模型 和 TCP/IP四层模型 数据传输单位、对应的设备 物理层:网线 数据链路层:网卡、网桥、交换机 网路层:路由器、网关 网卡的作用 网卡(Network Interface Card, NIC)是计算机上用于连接网络的硬件设备。 网卡是计算机连接网络、传…

机器学习实战笔记5数据标准化

1.读取csv文件实现特征化 import numpy as np import pandas as pd from sklearn.preprocessing import StandardScaler StandardScaler是一个用于标准化特征的工具,通过移除均值并缩放到单位方差来实现。 df pd.read_csv("./p039.csv") df scaler S…

windows10 安装CUDA教程

如何在windows10系统上安装CUDA? 1、查看电脑的NVIDIA版本 nvidia-smi 2、官网下载所需CUDA版本 官网地址:https://developer.nvidia.com/cuda-toolkit-archive 我们所安装的CUDA版本需要小于等于本机电脑的NVIDIA版本。推荐使用迅雷下载,速度会更快哦。 3、安装步骤

《你敢不学习?》numpy库——细细学<2>

续接上集: 1、reshape函数:重塑数组的形状 改变数组的维度 其语法为 numpy.reshape(arr, newshape, orderC) 如下图所示 首先生成一个1到17不包括17的16个元素的数组,然后对这个数组进行重塑,使其成为4行4列的二维数组,注意&…

性价比之争:上海闵行装修公司性价比大比拼

在繁华的上海,装修市场的竞争愈发激烈,业主们在追求品质的同时更加注重性价比。今天,我们就来对比几家知名的上海装修公司,看看哪家能在性价比之战中脱颖而出。 1.即住空间装饰即住空间以其“高质量、高效率”而被受消费者好评&a…

Python 使用TCP\UDP协议创建一个聊天室

server端代码: #encodingutf-8 # 服务端代码 import socketdef server():server_socket socket.socket(socket.AF_INET, socket.SOCK_STREAM)host socket.gethostname()port 12345server_socket.bind((host, port))server_socket.listen(5)print(等待客户端连接…

C++学习笔记03-对象和类(问题-解答自查版)

前言 以下问题以Q&A形式记录,基本上都是笔者在初学一轮后,掌握不牢或者频繁忘记的点 Q&A的形式有助于学习过程中时刻关注自己的输入与输出关系,也适合做查漏补缺和复盘。 本文对读者可以用作自查,答案在后面&#xff0…

C#,.NET常见算法

1.递归算法 1.1.C#递归算法计算阶乘的方法 using System;namespace C_Sharp_Example {public class Program{/// <summary>/// 阶乘&#xff1a;一个正整数的阶乘Factorial是所有小于以及等于该数的正整数的积&#xff0c;0的阶乘是1&#xff0c;n的阶乘是n&#xff0…

高效部署Modbus转MQTT网关:Modbus RTU、Modbus TCP转MQTT

钡铼Modbus转MQTT网关&#xff0c;简而言之&#xff0c;就是通过将Modbus协议&#xff08;包括Modbus RTU和Modbus TCP&#xff09;的数据转换为MQTT协议的数据格式&#xff0c;从而实现设备数据的上传和云端控制指令的下发。这一转换过程使得设备能够与基于MQTT协议的云平台进…

Harmony Next -- 通用标题栏:高度自定义,可设置沉浸式状态,正常状态下为:左侧返回、居中标题,左中右均可自定义视图。

hm_common_title_bar OpenHarmony三方库中心仓&#xff1a;https://ohpm.openharmony.cn/#/cn/detail/common_title_bar 介绍 一款通用标题栏&#xff0c;支持高度自定义&#xff0c;可设置沉浸式状态&#xff0c;正常状态下为&#xff1a;左侧返回、居中标题&#xff0c;左…

Vue3分段控制器(Segmented)

效果如下图&#xff1a;在线预览 APIs Segmented 参数说明类型默认值必传block是否将宽度调整为父元素宽度&#xff0c;同时所有选项占据相同的宽度booleanfalsefalsedisabled是否禁用booleanfalsefalseoptions选项数据string[] | number[] | SegmentedOption[][]falsesize控…

Vivado生成网表文件并创建自定义IP

平台&#xff1a;vivado2018.3 应用场景&#xff0c;在设计的过程中&#xff0c;我们一些特定的模块需要交付给别人&#xff0c;但是又不想让他们看到其中的源码。就可以将源码封装成网表和IP文件。 vivado生成网表文件 设置综合。设置-flatten_hierarchy* 为full。 这里可…

基于ansible进行运维自动化的研究以及相关的属性

一、ansible-简介 介绍 ansible是新出现的自动化运维工具&#xff0c;基于Python开发&#xff0c;集合了众多运维工具&#xff08;puppet、cfengine、chef、func、fabric&#xff09;的优点&#xff0c; 实现了批量系统配置、批量程序部署、批量运行命令等功能。 无客户端。 …

【香橙派开发板测试】:在黑科技Orange Pi AIpro部署YOLOv8深度学习纤维分割检测模型

文章目录 &#x1f680;&#x1f680;&#x1f680;前言一、1️⃣ Orange Pi AIpro开发板相关介绍1.1 &#x1f393; 核心配置1.2 ✨开发板接口详情图1.3 ⭐️开箱展示 二、2️⃣配置开发板详细教程2.1 &#x1f393; 烧录镜像系统2.2 ✨配置网络2.3 ⭐️使用SSH连接主板 三、…