正则表达式(一):基础命令及字符

news/2025/1/15 12:26:07/

正则表达式一-基础命令及字符

  • 一、常用命令补充:
    • 1.grep:
    • 2.sort:
    • 3.uniq:快速去重
    • 4.tr:
    • 5.cut:
    • 6.split:文件拆分
    • 7.paste:合并文件
    • 8.例题应用:
  • 二、正则表达式:
    • 1.定义:
    • 2.作用:
    • 3.通配符:
    • 4.正则表达式:

一、常用命令补充:

1.grep:

(1)作用:对文本进行过滤,支持正则表达式,针对行进行处理。

(2)常用选项:

选项作用
-i忽略字符大小写,可有可无。
-v显示不被pattern匹配到的行,即取反。
-w匹配整个单词。
-ffile根据模式文件,处理两个文件相同内容,把第一个文件作为匹配条件。
-n显示匹配的行号。
-c统计匹配的行数。
-e实现多个选项间的逻辑or关系。
-r递归目录,但是不处理软连接。
-E使用ERE,相当于egrep,使用扩展正则。
-o仅显示匹配到的字符串。
-A匹配当前行及他后面的行。
-B匹配当前行及他前面的行。
-R递归目录,处理软连接。

(3)运用:

1.-m  # 匹配指定次后停止
[root@test1 opt]# grep -m 1 root /etc/passwd#多个匹配只取第一个
root:x:0:0:root:/root:/bin/bash
2.-v #显示不被pattern匹配到的行,即取反
[root@test1 opt]# grep -v root /etc/passwd
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
3.grep -c root /etc/passwd 
[root@test1 opt]# grep -c root /etc/passwd 
4.grep -A3 root /etc/passwd   #匹配到的行的后3行也显示出来
[root@test1 opt]# grep -A3 root /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
--
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
5.将非空行写入到test.txt文件
[root@test1 opt]# cat wang.txt
nubobo
jioioo
nioioboi
9494949412121212212121210404040404046161616161616161[root@test1 opt]# vim wang.txt 
[root@test1 opt]# cat wang.txt | grep -v '^$' > test.txt
[root@test1 opt]# cat test.txt 
nubobo
jioioo
nioioboi
94949494
12121212
21212121
040404040404
6161616161616161

2.sort:

以行为单位,对文件内容进行排序,也可根据不同类型进行排序。

(1)常用选项:

选项作用
-f忽略大小写,默认情况下,大写字母排在前面。
-b忽略每行前面的空格,只排序不改缩进。
-n按数字进行正向排序。
-r按数字进行反向排序。
-u去重,去掉重复内容。
-o将排序后的结果输出到指定文件。

(2)应用:

1.忽略每行空格:

在这里插入图片描述

在这里插入图片描述

2.正向,反向排序:

在这里插入图片描述

3.去重:

在这里插入图片描述

在这里插入图片描述

3.uniq:快速去重

(1)格式:

1.cat 文件名 | uniq 选项

2.uniq 选项 参数

(2)常用选项:

选项作用
-c统计重复的行的次数,并且合并重复的行
-u显示仅出现一次的行(不连续重复出现的行也算出现一次)
-d显示重复出现的行(连续重复出现)

(3)应用:

1.统计重复出现的行的次数:
[root@test1 opt]# cat wang.txt | uniq -c 2 wangz3 billkin4 pp
2.去重排序:
[root@test1 opt]# cat wang.txt | uniq -c wang.txt | sort -n2 1billkin3 2wangz4 3pp

4.tr:

(1)作用:对来自标准输入的字符进行替换,压缩,删除。

(2)常用选项:

选项作用
-d删除字符集1的字符
-c保留字符集1的字符,其他字符用字符集2替换
-s把重复出现的字符串压缩成一个,把前一个替换成后一个
-t替换,默认选项,可以不加

(3)应用:

1.替换

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

2.压缩:

在这里插入图片描述

3.把重复出现的字符串替换为一个:

在这里插入图片描述

4.echo $PATH | tr -s “:” “\n” —把":"替换为换行

在这里插入图片描述

5.cut:

(1)格式:

1.cut 选项 参数

2.cat file | cut 选项

(2)常用选项:

选项作用
-d指定分隔符
-f按字段截取,跟上数字即表示截取第几段
-b以字节为单位截取
-c以字符为单位截取
-complemnt排除所有指定字段
-out-delimiter更改输出内容的分割符

(3)应用:

1.指定字段截取:

在这里插入图片描述

2.删除:
在这里插入图片描述

3.转换分隔符:

在这里插入图片描述

6.split:文件拆分

(1)常用选项:

选项作用
-l按行拆分
-b指定大小拆分

(2)格式:

1.split -b 指定大小 文件名 新文件名

2.split -l 指定行数 文件名 新文件名

7.paste:合并文件

(1)格式:

paste [选项] 文件1 文件2

(2)常用选项:

选项作用
-d用于指定文件的分隔符(默认情况下为制表符"\n")
-s将列和行的内容进行互相交换

(3)cat和paste的区别:

在这里插入图片描述

在这里插入图片描述

8.例题应用:

(1)统计当前主机连接状态:

[root@test1 opt]# ss -nta | grep -v '^State' | cut -d " " -f 1 | sort | uniq -c1 ESTAB11 LISTEN

(2)统计主机连接数:

[root@test1 ~]# ss -nt | tr -s " " | cut -d " " -f 4 | sort -n | uniq -c1 Local2 192.168.174.12:22

二、正则表达式:

1.定义:

​ 由一类特殊字符及文本字符所编写的模式,其中有些字符(元字符)不表示字符字面意义,而表示控制或通配的功能,类似于增强版的通配符功能,但与通配符不同,通配符功能是用来处理文件名,而正则表达式是处理文本内容中字符。

2.作用:

​ 主要用来匹配字符串(命令结果,文本内容)。

3.通配符:

(1)定义:只用于匹配文件名,目录名,不匹配文件内容。

(2)作用:为了方便用户对文件或者目录的描述,例如用户仅仅需要以".sh"结尾的文件时,使用通配符就能很方便地实现。各个版本的shell都有通配符,这些通配符是一些特殊的字符,用户可以在命令行的参数中使用这些字符,进行文件名或者路径名的匹配。shell将与与命令行中指定的匹配规则符合的所有文件名或者路径名作为命令的参数,然后执行这个命令。

(3)常用选项:

选项作用
*匹配一个或多个字符
匹配任意一个字符

4.正则表达式:

(1)元字符:

选项作用
.匹配任意一个单个字符,可以是汉字
()使用转义符,只表示()
[]匹配指定范围内的任意单个字符
[^]匹配指定范围外的任意单个字符
[[:blank:]]空白字符(空格和制表符)
[:space:]包括空格、制表符(水平和垂直)、换行符、回车符等各种类型的空白,比[:blank:]包含的范围广

(2)使用:

1.[root@test1 opt]# ls /opt/ | grep "t."  #过滤出仅包含字母"t"后跟任何其他字符的行

在这里插入图片描述

2.ls /opt/ | grep '[fhtx].txt'   #匹配[]中任意一个字符

在这里插入图片描述

3.ls | grep '[^a.z].txt'  #“[^a.z]”表示不匹配字母“a”或“z”的任何字符

在这里插入图片描述

4.grep [[:space:]] wang.txt #过滤空格

在这里插入图片描述

(3)匹配次数:

选项作用
*匹配前面字符的任意次数,包括0次,贪婪模式,尽可能长的匹配。
.*任意长度的任意字符,不包括0次,即匹配所有。
?匹配其前面的字符出现0或1次,即可有可无。
\+匹配其前面的字符至少出现1次,即肯定有且>=1次。
\{n\}匹配其前面的字符出现n次。
\{m,n\}匹配其前面的字符至少出现m次,至多n次。
\{,n\}匹配其前面的字符至多出现n次,<=n。
\{n,\}匹配其前面的字符至少出现n次。

次,即可有可无。 |
| \+ | 匹配其前面的字符至少出现1次,即肯定有且>=1次。 |
| \{n\} | 匹配其前面的字符出现n次。 |
| \{m,n\} | 匹配其前面的字符至少出现m次,至多n次。 |
| \{,n\} | 匹配其前面的字符至多出现n次,<=n。 |
| \{n,\} | 匹配其前面的字符至少出现n次。 |


http://www.ppmy.cn/news/251779.html

相关文章

priority_queue(优先级队列)模拟实现(堆方式)

目录 priority_queue初步介绍 堆 堆的模拟实现 接口实现 插入(push) AdJustUp(向上排序)接口 删除(pop) AdJustDown(向下排序算法) 适配器堆总结 仿函数 用仿函数对堆进一步封装 用堆进行封装优先级队列 代码总结 priority_queue初步介绍 priority_queue的性质是…

【Leetcode】701 二叉搜索树的插入\删除操作

701 二叉搜索树的插入 val比cur小就向左&#xff0c;比cur大就向右找到叶节点后插入 class Solution {public TreeNode insertIntoBST(TreeNode root, int val) {if (root null) {return new TreeNode(val);}// val比cur小就向左&#xff0c;比cur大就向右TreeNode cur roo…

32位uefi引导64位Linux,维护版win8pe(32位+64位+纯64位,支持BIOS+EFI)

此文件包的ISO格式&#xff0c;下载后解压即可得到ISO文件。 本合盘启动方式支持BIOS32位EFI64位EFI启动。写入方式支持量产&#xff0c;刻盘&#xff0c;B,U(不隐藏、普通隐藏、高端隐藏)。最大化支持新老机型启动。 制作这个合盘&#xff0c;是为了尽量适应各种情况&#xff…

w ndoWs8pE模式下载,windows pe官方版下载_windows pe v8.2 - Win7旗舰版

win7 PE是一款可安装在硬盘、U盘、光盘使用的Windows PE工具集合&#xff0c;可以快速帮用户实现一个独立于本地操作系统的临时win7操作系统&#xff0c;而且win7 PE完全在内存中运行的特性可以帮助你以极高的权限访问硬盘&#xff0c;是一个应急维护工具箱。 软件介绍 win7 PE…

绿色无广告版装机工具:微PE工具箱Win8/10内核版32/64位

你需要好用的WinPE工具箱吗&#xff0c;快来下载微PE工具箱Win10版使用吧。所谓微pe就是完整的精简&#xff0c;现在已有了W10PE核心&#xff0c;使用它可以灵活地安装到系统开机启动项、制作可启动U盘、移动硬盘以及生成ISO镜像&#xff0c;它不仅内核小并且工具十分的齐全&am…

纯净版PE制作工具

我们都知道&#xff0c;随着微软系统的不断更新迭代&#xff0c;好多朋友都学着自己去换系统&#xff0c;但是在百度里面一搜&#xff1a;【U盘制作工具】&#xff0c;什么大白菜啊&#xff0c;U深度啊&#xff0c;老毛桃啊乱七八糟的一大堆&#xff0c;可是明明自己在官网上下…

win7 64位在32位的win8PE下面的安装

&#xfeff;&#xfeff; 一、制作U盘启动盘 二、boot启动项设置&#xff08;自己百度哦&#xff09; 三、进入winPE系统&#xff1a; 1.格式化系统盘(默认C盘) 2.将系统ios镜像解压到D盘W7文件夹下&#xff0c;D:\W7 3. &#xff08;1&#xff09;拷贝D/W7下的boot文件…

官网版本的windows pe系统启动盘制作过程

官网版本的windows pe系统启动盘制作过程 一.下载 WinPE (Windows PE) 步骤1&#xff1a;下载并安装 Windows 评估和部署工具包 (ADK) 1.请使用与你正在使用的 Windows 版本匹配的 ADK 版本&#xff0c;下载地址https://docs.microsoft.com/en-us/windows-hardware/get-start…