Shell编程:正则表达式(位置锚定、分组或者、扩展正则)

2024-09-04 11:12

本文主要是介绍Shell编程:正则表达式(位置锚定、分组或者、扩展正则),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


文章目录

  • 正则表达式 2
    • 位置锚定
      • 行锚定
      • 单词锚定
      • 示例
    • 分组与其他
      • 分组
      • 或者
      • 示例
    • 扩展正则表达式
      • 表示次数
      • 表示分组
      • 示例


正则表达式 2

位置锚定

行锚定

  • ^ 行首锚定:用于模式的最左侧,表示匹配行首。
  • $ 行尾锚定:用于模式的最右侧,表示匹配行尾。

示例:

  • ^root$ 匹配整行,只有 “root” 的行。
  • ^$ 匹配空行。
  • ^[[:space:]]*$ 匹配空白行。

单词锚定

  • \<\b 词首锚定:用于单词模式的左侧,表示匹配词首(单词由连续的字母、数字、下划线组成)。
  • \>\b 词尾锚定:用于单词模式的右侧,表示匹配词尾。

示例:

  • \<root\> 匹配整个单词 “root”。

示例

  1. 过滤出不是以 # 号开头的非空行:

    grep "^[^#]" /etc/fstab
    
  2. 匹配整行内容为 “google” 的行:

    grep "^google$" test.txt
    
  3. 匹配空白行:

    grep "^[[:space:]]*$" /etc/fstab
    
  4. 匹配以单词 “123” 开头的字符串:

    echo hello-123 | grep "\b123"
    
  5. 匹配单词 “hello” 的字符串:

    echo hello-123 | grep "\bhello"
    
  6. 匹配以 “o-123” 为词首的字符串(匹配不到,因为 “o” 不是词首):

    echo hello-123 | grep "\bo-123"
    

分组与其他

分组

  • () 用于将多个字符捆绑在一起,当作一个整体处理。

或者

  • \| 用于表示逻辑“或”。

示例

  1. 匹配字符 c 出现 3 次的字符串:

    echo abccc | grep "abc\{3\}"
    
  2. 匹配字符串 “abcabcabc” 中的 “abc” 出现 3 次:

    echo abcabcabc | grep "\(abc\)\{3\}"echo abcabcabc | grep "\(ab\)\{3\}" 
    #不能匹配,因为要连续的出现才能匹配
    
  3. 匹配字符串 “golgogle” 中的 “go” 出现 1 次:

    echo golgogle | grep '\(go\)\{1\}'echo golgogle | grep  '\(go\)\{1\}gle' 
    #只能匹配后面的 golgogle
    
  4. 匹配字符串 “1abc” 中的字符 “1” 或 “2abc”:

    echo 1abc | grep "1\|2abc"
    
  5. 匹配字符串 “1abc2abc” 中的 “1abc” 或 “2abc”:

    echo 1abc2abc | grep "\(1\|2\)abc"
    

扩展正则表达式

扩展正则表达式可以使用 grep -Eegrep,或使用 sed -r。可以省去转义符 \ ,点 . 仍需要转义。(表示字符相差不大)

表示次数

  • * 匹配前面的字符任意次。
  • ? 匹配前面的字符 0 或 1 次。
  • + 匹配前面的字符 1 次或多次。
  • {n} 匹配前面的字符 n 次。
  • {m,n} 匹配前面的字符至少 m 次,至多 n 次。
  • {,n} 匹配前面的字符至多 n 次,n 可以为 0。
  • {n,} 匹配前面的字符至少 n 次,n 可以为 0。

表示分组

  • () 用于分组,将多个字符捆绑在一起。

  • | 用于表示逻辑“或”。

    a|b     #a或b
    C|cat   #C或cat
    (C|c)at #Cat或cat
    

示例

  1. 匹配 IP 地址:

    ifconfig ens33 | grep netmask | grep -E '[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+'
    
  2. 匹配电话号码:

    grep -E "[0-9]+-[0-9]+" number.txt
    

    输出示例:

    025-83346023
    0510-8776655
    0527-9888899
    
  3. 匹配邮箱地址:

    echo "544564317@qq.com" | grep -E "[0-9]+@[a-z]+\.[a-z]+"
    
  4. 匹配手机号:

    echo "13770725194" | grep -E "\b1[3456789][0-9]{9}\b"
    
  5. 匹配邮箱地址(包括大小写字母):

    echo "CICIfireway@163.com" | grep -E "[a-zA-Z]+@[0-9]+\.[a-z]+"
    
  6. 匹配混合字符的邮箱地址:

    grep -E "[a-zA-Z0-9]+@[0-9a-z]+\.[a-z]+" email.txt
    
  7. 匹配美国电话号码:

    grep -E '^(\([0-9]+\)|[0-9]+)[ -]?[0-9]+[ -]?[0-9]+' file.txt
    

    文件内容示例:

    987-123-4567
    987 456-1230
    (123) 456-7890
    

这篇关于Shell编程:正则表达式(位置锚定、分组或者、扩展正则)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1135860

相关文章

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

POJ1269 判断2条直线的位置关系

题目大意:给两个点能够确定一条直线,题目给出两条直线(由4个点确定),要求判断出这两条直线的关系:平行,同线,相交。如果相交还要求出交点坐标。 解题思路: 先判断两条直线p1p2, q1q2是否共线, 如果不是,再判断 直线 是否平行, 如果还不是, 则两直线相交。  判断共线:  p1p2q1 共线 且 p1p2q2 共线 ,共线用叉乘为 0  来判断,  判断 平行:  p1p

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念