前言
正则表达式是文本处理领域中的一个强大的工具,它可以让文本处理的能力呈指数级的提升,如果一款文本编辑器不支持正则表达式,那么它就算不上是一个现代化的编辑器,这绝非虚言。
下面这篇文章主要跟大家介绍了关于Vim查找替换及正则表达式使用的相关内容,分享出来供大家参考学习,下面来一起看看吧。
简单替换表达式
:[range]s/from/to/[flags]
range:搜索范围,如果没有指定范围,则作用于但前行。
:1,10s/from/to/ 表示在第1到第10行(包含第1,第10行)之间搜索替换; :10s/from/to/ 表示只在第10行搜索替换; :%s/from/to/ 表示在所有行中搜索替换; 1,$s/from/to/ 同上。flags 有如下四个选项:
c confirm,每次替换前询问; e error, 不显示错误; g globle,不询问,整行替换。如果不加g选项,则只替换每行的第一个匹配到的字符串; i ignore,忽略大小写。这些选项可以合并使用,如cgi表示不区分大小写,整行替换,替换前询问。
正则表达式
1、元字符
元字符
| 元字符 | 说明 |
|---|---|
| . | 匹配任意字符 |
| [abc] | 匹配方括号中的任意一个字符,可用-表示字符范围。如[a-z0-9]匹配小写字母和数字 |
| [^abc] | 匹配除方括号中字符之外的任意字符 |
| d | 匹配阿拉伯数字,等同于[0-9] |
| D | 匹配阿拉伯数字之外的任意字符,等同于[^0-9] |
| x | 匹配十六进制数字,等同于[0-9A-Fa-f] |
| X | 匹配十六进制数字之外的任意字符,等同于[^0-9A-Fa-f] |
| l | 匹配[a-z] |
| L | 匹配[^a-z] |
| u | 匹配[A-Z] |
| U | 匹配[^A-Z] |
| w | 匹配单词字母,等同于[0-9A-Za-z_] |
| W | 匹配单词字母之外的任意字符,等同于[^0-9A-Za-z_] |
| t | 匹配<TAB>字符 |
| s | 匹配空白字符,等同于[t] |
| S | 匹配非空白字符,等同于[^t] |
一些普通字符需转意








