使用Vim处理文本

1. 使用Vim提取文本内容

考虑以下场景:Vim教程网为了增加在百度上的收录量,需要调用百度站长平台提供的主动推送接口实时推送链接。为此,需要将准备提交的链接按照每行一条的格式写入一个文本文件中。

vim处理文本

而Vim教程网是有提供https://vimjc.com/sitemap.xml文件的,里面包含了教程网上所有的Vim教程文章,因此,只需要对sitemap.xml文件进行必要的处理,提取出所有文章的url即可。

为了提取出sitemap.xml中的所有文章url,可以使用Vim进行如下操作。

  • 首先,在Vim命令行模式下使用命令 :v/loc/d 删除掉sitemap.xml文件中不包含 loc 的行
  • 其次,使用Vim搜索命令 /\v *\<\/?\w+\> 选中 标记
  • 最后,使用Vim替换命令 :%s///g 删除选中的loc标记和空格
vim处理文本

:v/loc/d 命令是使用 :vglobal 命令的缩写形式执行与 :global 命令完全相反的操作,用于实现删除所有不包含 loc 的行,更多内容可以参考文章Vim global命令和重复操作。

/\v *\<\/?\w+\> 用Vim的very magic正则匹配模式依次匹配零个或任意个空格、再匹配左尖括号 (<)、匹配可选的正斜杠 (/?)、匹配一个或多个单词型字符 (\w+)、匹配右尖括号 (>)。从而搜索出所有包含尖括号的目标字符。

:%s///g 命令是使用Vim的替换命令 :s (全称为 :substitute) 将源字符串串替换为目标串(空格),由于substitute命令没有显式指定源串,所以substitute命令会沿用上次的查找模式 (即/\v *\<\/?\w+\>),更多内容可以参考文章substitute重用上次的查找模式

2. 将 CSS 文件中所有规则的属性按字母排序

假设我们想把某个CSS文件中每一组样式规则内的属性都按照字母顺序排序。可以借助 Vim 的内置命令 :sort 配合 :global 命令实现这一功能。

vim处理文本

:g/{/ .+1,/}/-1 sort 命令是使用 :global 命令在指定的文件范围内执行 sort 命令。为了分析这个Vim命令的含义,将其拆分成以下几个部分。

.+1,/}/-1 的基本形式为 .,/}/,其含义是 从当前行开始,直到匹配到模式 /}/ 的那一行为止。偏移值 +1 与 —1 用于缩小操作范围,把操作对象集中在 {} 之间的内容上面。

/{/ 命令令会将光标置于某个 {} 块的起始位置。

所以,参考Vim global命令格式可分析出,:g/{/ .+1,/}/-1 sort 命令指定的模式 { 会匹配每个 {} 块的起始行。而对于每个匹配行,:sort 会从匹配行到 {} 块的结尾这个范围内执行。

最终,每一条规则的 CSS 属性都会按照字母顺序排列整齐。


原文链接:使用Vim处理文本-Vim使用技巧(9)

你可能感兴趣的:(使用Vim处理文本)