查找进阶

回忆上节课内容

  • 实时搜索 :set incsearch
  • 大写小写 ignorecase
  • 查找当前单词

    • * 正向按单词
    • # 反向按单词
    • g* 正向不按单词
    • g# 反向不按单词
  • 继续查找

    • n 保持方向
    • N改变方向
  • 这个搜索可以做一些模糊匹配吗?
  • 应该在哪里查询呢?

模式匹配

  • :h / 可以找到关于搜索相关的帮助

    • 我们可以打开 patterns.txt
    • 找到关于比较简单的解释 03.9 的超链接位置
    • ctrl + ] 跳转文档

行头行尾

  • /include 匹配所有的 include
  • ^ 意味着行开头

    • /^include 只匹配 include 在行头的
    • /^# 只匹配 # 在行头的
  • $ 意味着行结尾

    • /the.$ 只匹配 the. 在行尾的
    • /^End$ 匹配行头接着 End,然后就是行尾的一行
  • :g/^$/d 删除所有空行
  • 行头行尾和词头词尾很像
  • ^ 本身就是跳到行头
  • $ 本身就是跳到行尾

任意字符

  • . 可以匹配任意字符,作为通配符来使用
  • 比如 /c.m

    • 第一个字符为 c
    • 第二个字符为 . 就是任意字符
    • 第三个字符为 m
  • 可以匹配 company 中的 com
  • 也可以匹配 camera 中的 cam

任意字符

  • ter. 匹配 ter 后面加一个字符

  • 如果想要正常匹配一个真的 .

    • 就要加上一个反斜杠 \
    • 写做 \.
    • 使用反斜杠 \ 转义之后

      • .就不再代表任意字符了
      • 比如搜索 /ter\. 就是寻找 ter.

更多字符

  • . 代表任意字符

    • /c.m 匹配 c和m中间有一个字符 的情况
    • /c..m 匹配 c和m中间有两个字符 的情况
    • /c...m 匹配 c和m中间有三个字符 的情况
  • 如果我想查找 c 和 m 中间有任意多个字符怎么办?

    • 使用 * 通配符
    • /a* 意味着出现 0 到任意多个 a

      • /c.*mcm 中间出现 0 到任意多个 .(任意字符)
      • 如果我希望出现任意多次的是小写字母怎么办?

        • /c[a-z]*m 这样就是中间出现任意多个 [a-z]小写字母
  • :g/^s*$/d 删除搜有只有空格和tab的行

    • s代表空格和tab

词头词尾

  • ^$ 分别代表着行头和行尾
  • 再回一下词头词尾
  • 如果我想找出单词的开头结尾是某些字符的怎么办呢?

  • \< 意味着单词开头

    • /\<a 意味着 a 开头的单词
  • \>意味着单词结尾

    • /\>b 意味着 b 结尾的单词
  • \<a[a-z]*\>b

    • 意味着以 a 开头,b 结尾,ab 之间可能有零到任意多个字符的单词

搜索历史

  • 我们使用 *# 查找的时候就自动给加上这个词头词尾

    • 可以 * 之后
    • /
    • 配合上下方向键看到
    • 曾经的搜索记录

推荐网站

总结

  • 行头行尾

    • ^ 意味着行开头
    • $ 意味着行结尾
  • 任意字符

    • . 代表任意字符
    • [a-z] 代表任意小写字母
  • 字符数量

    • * 代表 0 到任意多个前字符
    • + 代表 1 到任意多个前字符
    • ? 代表 0 或 1 个前字符
  • 行头行尾

    • \< 意味着单词开头
    • \> 意味着单词结尾
  • 正则表达式的初步规则先介绍到这里
  • 我们掌握了在 vi 中光标运动的各种方法
  • 但如何编辑文本呢?
  • 下次再说

[Github地址] (https://github.com/overmind1980/vimtutorial)

[Gitee地址] (https://gitee.com/overmind1980/vimtutorial)

[蓝桥实验楼 邀请码FJWYIMGB] (https://www.lanqiao.cn/courses/2840)

oeasy教您玩转vim - 35 - # 正则表达的更多相关文章

  1. oeasy教您玩转vim - 56 - # 字符可视化模式

    ​ 可视化编辑 回忆上节课内容 我们学习了关于模式匹配中使用参数 单个参数 :%s/<h2>\(.*\)</h2>/ - \1/g 多个参数 :%s/<img src=\ ...

  2. oeasy教您玩转vim - 57 - # 行可视化

    ​ 可视化编辑 回忆上节课内容 上次我们了解到可视模式 其实可视化对应三种子模式 字符可视模式 v 行可视模式 大写V 块可视模式ctrl+v 我们先来了解字符可视化模式 快捷键 v 可配合各种mot ...

  3. oeasy教您玩转vim - 53 - # 批量替换

    查找细节 回忆上节课内容 我们温习了关于搜索的相关内容 /正向,?反向 n保持方向,N改变方向 可以设置 是否忽略大写小写 是否从头开始查找 是否高亮显示 还有一些正则表达式的使用方法 行头行尾 ^$ ...

  4. oeasy教您玩转linux010203显示logo

    我们来回顾一下 上一部分我们都讲了什么?

  5. oeasy 教您玩转linux010101查看内核uname

    linux([?l?n?ks]) 是什么????? 咱们这次讲点什么呢?这次咱们讲讲这个 linux([?l?n?ks]),什么是 linux([?l?n?ks])呢?这linux([?l?n?ks] ...

  6. oeasy教您玩转linux010202软件包管理apt

    顾一下 上一部分我们都讲了什么?

  7. oeasy教您玩转linux010201持续输出yes

    我们来回顾一下 上一部分我们都讲了什么?

  8. oeasy教您玩转linux010108到底哪个which

    到底哪个which 回忆上次内容 我们上次讲了查找命令位置whereis 我想找到whereis的位置怎么办?

  9. oeasy教您玩转python - 006 - # hello world

    ​ Hello World! 回忆上次内容 python3 的程序是一个 5.3M 的可执行文件 python3 里面全都是 cpu 指令 可以执行的那种指令 我们可以把指令对应的汇编找到 objdu ...

  10. oeasy教您玩转linux-010110内容回顾

    我们来回顾一下 我们都讲了什么?

随机推荐

  1. Three加载3D模型贴图

    Three加载3D模型贴图 准备阶段 3D模型 three 库文件 纹理图片 相关资料 官方开发文档: https://threejs.org/docs 官网编辑3D模型:https://threej ...

  2. layui-框架学习小总结

    主要6点: 1.导航栏变成了类似tab的页签,支持关闭,点击刷新. 2.左侧菜单树可隐藏. 3.树的搜索. 4.表格的新增行,并保存到后台. 5.表格 加载 下拉框,并赋值,选择了值后把值同步到表格对 ...

  3. 基于Ubuntu20.04在k8s 1.25部署gin+MySQL服务

    0. 前言 某天突发奇想,既然都学了 docker 了,那干脆,顺便把 kubernetes 也学了,于是开始了我长达一个月的环境搭建.踩坑历程. 最开始,我的想法是,在我的物理机使用 WSL + d ...

  4. 详解Spring循环依赖

    一. 什么是循环依赖 循环依赖,就是两个或则两个以上的bean互相依赖对方,最终形成闭环.比如"A对象依赖B对象,而B对象也依赖A对象",或者"A对象依赖B对象,B对象依 ...

  5. 一文带你了解.NET能做什么?

    前言 在DotNetGuide技术社区微信交流群经常看到有小伙伴问:.NET除了能写桌面应用和Web应用还能做什么?今天大姚将通过本篇文章来简单讲讲.NET能做哪些开发,对.NET感兴趣的小伙伴也可以 ...

  6. CSS——2D转换

  7. golang kmp算法实现

    // 不多逼逼直接上代码.原理的话可以参考下面的链接.讲的非常清晰package main import "fmt" func genNext(s string) []int { ...

  8. .NET常用库-Ocelot

    一 介绍 1.简介 Ocelot是一个.NET API网关. Ocelot仅适用于.NET Core,目前是为netstandard2.0构建的. Ocelot是一组按特定顺序排列的中间件. Ocel ...

  9. QShop商城-开发规范

    QShop商城-项目介绍 QShop商城,是全新推出的一款轻量级.高性能.前后端分离的电商系统,支持微信小程序,前后端源码100%开源,完美支持二次开发,让您快速搭建个性化独立商城. 技术架构:.Ne ...

  10. vue绑定下拉框 vue修饰符

    <select v-model="selected"> <option>请选择</option> <option>HTML</ ...