首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在notepad++中查找和修复不匹配的xml结束标记

在notepad++中查找和修复不匹配的xml结束标记
EN

Stack Overflow用户
提问于 2016-10-08 20:16:36
回答 2查看 2.8K关注 0票数 1

我试图简化在xml文件中纠正丢失的不匹配的verse标记的过程,该文件如下所示:

代码语言:javascript
复制
    <verse number="21">words words words asdlkjf alsdf. </verse>
    <verse number="22">words words words arbitrary words. 
      <verse number="23">more arbitrary text.</verse>
      <verse number="23">other arbitrary words. </chapter>

我想使用notepad++中的正则表达式来查找以任意空格和<verse开头但不以</verse>结尾的行的末尾。

在行尾匹配的情况下,我应该可以使用notepad++查找/替换将丢失的标记添加回。

下面是我到目前为止所得到的,它匹配以空格和<verse开头的每一行(不幸的是整行)。

代码语言:javascript
复制
^( +<verse).*
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-10-08 20:34:45

这可能就是你要找的东西:

查找: (^\h+<verse(?!.*verse>\h*).*?)((</.*?>\h*)*)$

替换: $1</verse>$2

给定样本数据,它将进行两次替换,结果如下:

代码语言:javascript
复制
    <verse number="21">words words words asdlkjf alsdf. </verse>
    <verse number="22">words words words arbitrary words. </verse>
      <verse number="23">more arbitrary text.</verse>
      <verse number="23">other arbitrary words. </verse></chapter>
票数 2
EN

Stack Overflow用户

发布于 2016-10-08 20:34:00

不可能匹配行的末尾,但可以匹配整行,并将其与缺失的结束标记放在一起:

代码语言:javascript
复制
Find: ^ *<verse>(.(?!</verse>))*(</\w*>)?$
Repl: $0</verse>$1
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39936935

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档