首页 / C#开发 / 正文

.NET(C#)用正则表达式清除HTML标签(包括script和style),保留纯本文

13093 发布于: 2014-11-25 读完约需3分钟
如今是互联网时代,随时随刻都在接触网页数据。那么对于.NET的开发人员来说,处理网页源码就是有时候就不能避免了。今天给大家分享.NET用正则表达式清除HTML标签的通用方法。使其保留网页源码中的纯文本,具体方法:
#region 去掉HTML中的所有标签,只留下纯文本
    /// <summary>
    /// 去掉HTML中的所有标签,只留下纯文本
    /// </summary>
    /// <param name="strHtml"></param>
    /// <returns></returns>

    public static string CleanHtml(string strHtml)
    {
      if (string.IsNullOrEmpty(strHtml)) return strHtml;
      //删除脚本
      //Regex.Replace(strHtml, @"<script[^>]*?>.*?</script>", "", RegexOptions.IgnoreCase)
      strHtml = Regex.Replace(strHtml, "(\<script(.+?)\</script\>)|(\<style(.+?)\</style\>)", "", RegexOptions.IgnoreCase | RegexOptions.Singleline);
      //删除标签
      var r = new Regex(@"</?[^>]*>", RegexOptions.IgnoreCase);
      Match m;
      for (m = r.Match(strHtml); m.Success; m = m.NextMatch())
      {
        strHtml = strHtml.Replace(m.Groups[0].ToString(), "");
      }
      return strHtml.Trim();
    }

    #endregion
 

版权声明:本作品系原创,版权归码友网所有,如未经许可,禁止任何形式转载,违者必究。

上一篇: 推荐SQLite的可视化管理工具之SQLiteStudio--轻便,小巧,绿色,无需安装

下一篇: 分享一篇关于SQL Server处理每天亿级数据(历史数据)的博文--也许你可以借鉴些许

本文永久链接码友网 » .NET(C#)用正则表达式清除HTML标签(包括script和style),保留纯本文

分享扩散:

发表评论

登录用户才能发表评论, 请 登 录 或者 注册