当前位置 : 主页 > 网络编程 > 正则表达式 >

一个替换目录结构的正则表达式 实现目录的增加

来源:互联网 收集:自由互联 发布时间:2020-11-08
需要解决如下操作: 有多个shtml文件,里面有连接地址 https://www.jb51.net/fgdf/222/1234.shtml https://www.jb51.net/tyty/333/456456.shtml https://www.jb51.net/tyry/789/fsdfsfs.shtml 现在我我想把这些.shtml文件连接
需要解决如下操作:
有多个shtml文件,里面有连接地址
https://www.jb51.net/fgdf/222/1234.shtml
https://www.jb51.net/tyty/333/456456.shtml
https://www.jb51.net/tyry/789/fsdfsfs.shtml
现在我我想把这些.shtml文件连接地址前面加个目录名 inc 就是变成
https://www.jb51.net/fgdf/222/inc/1234.shtml
https://www.jb51.net/tyty/333/inc/456456.shtml

解决方法:一般来说editplus等支持正则表达式的软件就可以了
查找目标:
复制代码 代码如下:
^(.+/)(.+)$

替换为:
复制代码 代码如下:
\1inc/\2


记得在下面的"查找模式"上选中 "正则表达式"
再顺便讲一下上面的正则是什么意思,
^(.+/)(.+)$
^ 匹配每一行的开头
$ 匹配每一行的结尾
(.+/) 匹配 从当前行的开始到最后一个 / 括号在这里表示捕获这个分组,然后才可以在正面的替换为里面使用 \1 来代表这个正则所匹配的内容
(.+) 匹配当前行的最后一个 / 的右边的字符起到这一行的结尾 (第二个捕获分组 \2)
上面的整个正则的意思是 从当前行的第一个字符找到最后一个 / 做为第一个分组,剩余的做为第二个分组
替换为: \1inc/\2
中的 \1 就是上面所说的第一个分组所匹配到的内容 \2 是第二个分组所匹配到的内容 inc/ 是你想要在中间中上的字符
所以合在一起就可以达到你想要的目的了.
即:
https://www.jb51.net/12/234/678.html
https://www.jb51.net/12/234/ 为 分组一所匹配到的字符(\1)
678.html 为分组二所匹配到的字符(\2)
然后再结合替换为里面的内容,替换后的结果为
https://www.jb51.net/12/234/inc/678.html
网友评论