V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Dive into HTML5
http://diveintohtml5.org/
lastcode
V2EX  ›  HTML

关于正则表达式的问题,批量修改有相同内容的行

  •  
  •   lastcode · 2023-10-13 21:05:59 +08:00 · 1281 次点击
    这是一个创建于 444 天前的主题,其中的信息可能已经有所发展或是发生改变。
    想做个 epub 的电子书,有什么办法能批量的给每章章节名两边加上[h1] [/h1]的标签

    章节名格式是这样的

    第一章 xxxxxxx

    批量把章节名加上标题的标签,变成[h1] 第一章 xxxxxxx[/h1]
    3 条回复    2023-10-15 06:55:37 +08:00
    kxks145
        1
    kxks145  
       2023-10-13 21:13:47 +08:00 via Android   ❤️ 1
    (第.+?章 .+)替换成[h1]\1[/h1]
    lastcode
        2
    lastcode  
    OP
       2023-10-13 22:07:43 +08:00
    @kxks145 谢谢!
    netabare
        3
    netabare  
       2023-10-15 06:55:37 +08:00   ❤️ 1
    用`()`和`$x`(这里的 x 是数字,从 1 开始)来替换。

    假设你这里每一个标题都是单独一行的话,那么每一行只捕获一次匹配,那么需要的就是先提取出每一个标题:

    `(^第.*章.*$)` - 这里`^`假设标题紧跟着每行开头开始,如果不是的话就要去掉,如果每个标题有更多特征,比如有固定字数,可以进一步限定进去

    然后在替换栏里面输入要替换后的模式,括号里面括住的部分用`$1`来指代,那么就是:

    `[h1]$1[\\h2]` - h2 前面的反斜杠要转义一下(有的语言里可能会不一样)。

    如果 op 有用 IDEA 的话,可以试试用 IDEA ,里面会对正则表达式替换有预览的。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1097 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 82ms · UTC 18:54 · PVG 02:54 · LAX 10:54 · JFK 13:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.