asp.net正则表达式删除指定的HTML标签的代码
程序员文章站
2024-03-08 12:27:10
如果全盘删除里面的 html 标签,可能会造成阅读上的困难(比如 a, img 这些标签), 最好是删除一部分,保留一部分. 正则表达式里,判断 包含某些字符串 是非常容易...
如果全盘删除里面的 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 断言.
<(?!((/?\s?li\b)|(/?\s?ul)|(/?\s?a\b)|(/?\s?img\b)|(/?\s?br\b)|(/?\s?span\b)|(/?\s?b\b)))[^>]+>
private static string removespecifyhtml(string ctx) {
string[] holdtags = { "a", "img", "br", "strong", "b", "span", "li" };//保留的 tag
// <(?!((/?\s?li\b)|(/?\s?ul\b)|(/?\s?a\b)|(/?\s?img\b)|(/?\s?br\b)|(/?\s?span\b)|(/?\s?b\b)))[^>]+>
string regstr = string.format(@"<(?!((/?\s?{0})))[^>]+>", string.join(@"\b)|(/?\s?", holdtags));
regex reg = new regex(regstr, regexoptions.compiled | regexoptions.multiline | regexoptions.ignorecase);
return reg.replace(ctx, "");
}
正则表达式里,判断 包含某些字符串 是非常容易理解的,但是如何判断 不包含某些字符串 (是字符串,不是字符,是某些,不是某个) 确实是个费解的事.
复制代码 代码如下:
<(?!((/?\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 断言.
复制代码 代码如下:
<(?!((/?\s?li\b)|(/?\s?ul)|(/?\s?a\b)|(/?\s?img\b)|(/?\s?br\b)|(/?\s?span\b)|(/?\s?b\b)))[^>]+>
private static string removespecifyhtml(string ctx) {
string[] holdtags = { "a", "img", "br", "strong", "b", "span", "li" };//保留的 tag
// <(?!((/?\s?li\b)|(/?\s?ul\b)|(/?\s?a\b)|(/?\s?img\b)|(/?\s?br\b)|(/?\s?span\b)|(/?\s?b\b)))[^>]+>
string regstr = string.format(@"<(?!((/?\s?{0})))[^>]+>", string.join(@"\b)|(/?\s?", holdtags));
regex reg = new regex(regstr, regexoptions.compiled | regexoptions.multiline | regexoptions.ignorecase);
return reg.replace(ctx, "");
}
推荐阅读
-
asp.net正则表达式删除指定的HTML标签的代码
-
asp.net下遍历页面中所有的指定控件的代码
-
点击图片,AJAX删除后台图片文件的实现代码(asp.net)
-
asp.net gridview实现全选,反选与删除记录的操作代码
-
Asp.net使用HttpModule压缩并删除空白Html请求的实现代码
-
asp.net正则表达式删除指定的HTML标签的代码
-
点击图片,AJAX删除后台图片文件的实现代码(asp.net)
-
asp.net gridview实现全选,反选与删除记录的操作代码
-
用Html5与Asp.net MVC上传多个文件的实现代码
-
Asp.net使用HttpModule压缩并删除空白Html请求的实现代码