html解析器c#,C# HTML解析工具HtmlAgilityPack使用实例(一)

一、生成HTML字符串

//生成DOM字符串结构 HtmlNode container = HtmlNode.CreateNode("

"); title.InnerHtml = "张三丰"; HtmlNode link = HtmlNode.CreateNode(" "); link.InnerHtml = "点击进入"; link.SetAttributeValue("href", "http://wwww.gongjuji.net"); container.AppendChild(title).AppendChild(link); Console.WriteLine(container.OuterHtml);

eaba8b253c95d05a68ea940956b59970.png

二、解析HTML字符串或本地html文件

//解析html 字符串或者本地html文件 HtmlDocument doc = new HtmlDocument(); string html = "

Hello

"; doc.LoadHtml(html); HtmlNode demo = doc.GetElementbyId("demo"); Console.WriteLine(demo.InnerHtml); //注:InnerText中会有换行或空格等,需要特殊处理 Console.WriteLine(demo.InnerText); Console.WriteLine(demo.InnerText.Length);

b7f314cf137f2ee1c66ba57d9fcba14c.png

三、解析处理结合XPath使用更加方便

XPath简明介绍

XPath 使用路径表达式来选取 XML 文档中的节点或节点集。节点是通过沿着路径 (path) 或者步 (steps) 来选取的。

下面列出了最有用的路径表达式:

nodename:选取此节点的所有子节点。

/:从根节点选取。

//:从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。

.:选取当前节点。

..:选取当前节点的父节点。

例如有下面一段XML:

<?xml version="1.0" encoding="utf-8"?> 在ASP.NET中使用Highcharts js图表http://zhoufoxcn.blog.51cto.com/792419/5373242011-04-07 Log4Net使用详解(续)http://blog.csdn.net/zhoufoxcn/archive/2010/11/23/6029021.aspx2010年11月23日 J2ME开发的一般步骤http://blog.csdn.net/zhoufoxcn/archive/2011/06/12/6540223.aspx2011年06月12日 PowerDesign高级应用http://zhoufoxcn.blog.51cto.com/792419/1664152007-09-08

针对上面的XML文件,我们列出了带有谓语的一些路径表达式,以及表达式的结果: /Articles/Article[1]:选取属于Articles子元素的第一个Article元素。   /Articles/Article[last()]:选取属于Articles子元素的最后一个Article元素。   /Articles/Article[last()-1]:选取属于Articles子元素的倒数第二个Article元素。   /Articles/Article[position()<3]:选取最前面的两个属于 bookstore 元素的子元素的Article元素。   //title[@lang]:选取所有拥有名为lang的属性的title元素。   //CreateAt[@type=‘zh-cn‘]:选取所有CreateAt元素,且这些元素拥有值为zh-cn的type属性。   /Articles/Article[Order>2]:选取Articles元素的所有Article元素,且其中的Order元素的值须大于2。   /Articles/Article[Order<3]/Title:选取Articles元素中的Article元素的所有Title元素,且其中的Order元素的值须小于3。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值