asp.net正则表达式删除指定的HTML标签的代码

来源:爱站网时间:2019-09-12编辑:网友分享
在抓取网页的数据的时候,如果网页按原样显示,它可能会因为不包含闭合的html标记而中断格式,或者它可能会使用更混乱的html标记来中断保留的格式,下面爱站技术频道小编就给大家介绍asp.net正则表达式删除指定的HTML标签的代码。

在抓取网页的数据的时候,如果网页按原样显示,它可能会因为不包含闭合的html标记而中断格式,或者它可能会使用更混乱的html标记来中断保留的格式,下面爱站技术频道小编就给大家介绍asp.net正则表达式删除指定的HTML标签的代码。

如果全盘删除里面的 HTML 标签,可能会造成阅读上的困难(比如 a, img 这些标签), 最好是删除一部分,保留一部分.

正则表达式里,判断 包含某些字符串 是非常容易理解的,但是如何判断 不包含某些字符串 (是字符串,不是字符,是某些,不是某个) 确实是个费解的事.

复制代码 代码如下:

<(?!((/?\s?li)|(/?\s?ul)|(/?\s?a)|(/?\s?img)|(/?\s?br)|(/?\s?span)|(/?\s?b)))[^>]+>


这个正则是判断HTML标签不包含 li / ul / a / img / br / span / b 的,就上面的要求来说,是要 删除 除这里列出的HTML标签,这也是我摸索了很长时间才搞出来的.
(?!exp) 匹配后面跟的不是exp的位置
/?\s? 我一开始试着把它写到最前面的 < 后面,但是测试失败了.

下面是一个简单的函数,把要保留的TAG串起来,生成一个正则表达式,然后把不需要的TAG删除...

 

复制代码 代码如下:

 


private static string RemoveSpecifyHtml(string ctx) {
string[] holdTags = { "a", "img", "br", "strong", "b", "span" };//要保留的 tag
// <(?!((/?\s?li)|(/?\s?ul)|(/?\s?a)|(/?\s?img)|(/?\s?br)|(/?\s?span)|(/?\s?b)))[^>]+>
string regStr = string.Format(@"<(?!((/?\s?{0})))[^>]+>", string.Join(@")|(/?\s?", holdTags));
Regex reg = new Regex(regStr, RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.IgnoreCase);


return reg.Replace(ctx, "");
}


修正:
上面的正则,如果保留了 li , 实际运行会发现 link 也给保留下来了, 保留 a 会把 addr 也给保留下来, 解决办法就是加 \b 断言.

 

 

 通过上述的介绍,大家对asp.net正则表达式删除指定的HTML标签的代码了解了多少呢?其实小编只是略略的讲了一些,如需更多专业的知识,请咨询爱站技术频道。

上一篇:总结c# datatable用法

下一篇:终极绝杀技之防止重复提交的方法

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载