正则表达式 查找以某些字符开始 某些字符结束的匹配项 解决之道

一个字符串里大致内容如下:

!$(P05Y200003630653)
Pol_type~LIFE~~=50%
Resv_desc~列金额加上因红利分配而产生的相关利益。
Resv_desc~上表所列的现金价值不包括因红利分配而产生
Resv_desc~如有未列年度及事项,详见合同条款。
%%EOJ
!$(P05Y200003630653)
Pol_type~LIFE~~
Resv_de=80%
Resv_desc~
Resv_desc~的相关利益。
Resv_desc~如有未列
%%EOJ

想要计算以上串中,以“!$”开始,以“%%EOJ”结束,的数据对的个数。
c#中相应的正则表达式怎么写?自己没想到好的实现方法。
!$(中间部分)%%EOJ

这中间部分有以下要求:
1. 至少包含一个字符,那就涉及到[]+了
2. 使用懒惰匹配模式,找最近的%%EOJ配对。或者写一个表达式保证这个串中不包含%%EOJ的字串。

我的结束标记的每个字符都可能在开始结束标记之间的内容中出现。

自己被陷进去了,突然之间想到办法了。哈哈哈,乐死我了,人的脑子怎么这样了。那么迟钝了,但是偶尔会发光。

1. 我先把整个字符串进行一次替换,将!$替换为<url>,将%%EOJ替换为</url>。当然也可以是其他的标签,这里只是看到别人的问题,顺便引用了一下。做替换的目的关键在与将开始结束标签替换为他们之间的数据不会出现的字符,例如,<在我要处理的文件中是肯定不会出现的,这对我来说已经是足够了。

替换之后字符串成这样了:
<url>(P05Y200003630653)
Pol_type~LIFE~~=50%
Resv_desc~列金额加上因红利分配而产生的相关利益。
Resv_desc~上表所列的现金价值不包括因红利分配而产生
Resv_desc~如有未列年度及事项,详见合同条款。
</url>
<url>(P05Y200003630653)
Pol_type~LIFE~~
Resv_de=80%
Resv_desc~
Resv_desc~的相关利益。
Resv_desc~如有未列
</url>

2. 然后就可以用下面的了。呵呵呵
<url>[^<]*</url>


 

你可能感兴趣的:(正则表达式)