[英]C#: Regex match closest
<table class="listProvision" class="itable">
<tr>
<td class="whatever">some infos</td>
<td>some more infos</td>
<td>13908402</td>
<td>hello world</td>
</tr>
<tr>
<td class="whatever">some infos</td>
<td>some more infos</td>
<td id="num">13908402</td>
<td>hello world</td>
</tr>
</table>
给定以上示例HTML, 我如何正确地解析具有类listProvision
的table
之间所有<tr>...</tr>
存在 ?
我试过了: <table.*?listProvision.*?>(?:.*?<tr.*?>(.*?)</tr>)+.*?</table>
,但是我不知道找出问题所在。 永远不会有任何复杂的html放入此正则表达式中,因此不必担心。
这是如何使用HTML Agility Pack解析html字符串的示例
HtmlDocument doc = new HtmlDocument();
doc.LoadHtml(html);
var rows = doc.DocumentNode
.SelectNodes("//table[@class='listProvision']/tr");
然后,您可以使用HtmlNode.InnerHtml
属性获取<tr>...</tr>
标记之间的所有数据。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.