博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# HTML解析工具HtmlAgilityPack使用实例(一)
阅读量:4287 次
发布时间:2019-05-27

本文共 2006 字,大约阅读时间需要 6 分钟。

一、生成HTML字符串

//生成DOM字符串结构HtmlNode container = HtmlNode.CreateNode("
");HtmlNode title = 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);

二、解析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);

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

XPath简明介绍
 XPath 使用路径表达式来选取 XML 文档中的节点或节点集。节点是通过沿着路径 (path) 或者步 (steps) 来选取的。
 下面列出了最有用的路径表达式:
 nodename:选取此节点的所有子节点。 
 /:从根节点选取。 
 //:从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。 
 .:选取当前节点。 
 ..:选取当前节点的父节点。

 例如有下面一段XML:
 

在ASP.NET中使用Highcharts js图表
http://zhoufoxcn.blog.51cto.com/792419/537324
2011-04-07
Log4Net使用详解(续)
http://blog.csdn.net/zhoufoxcn/archive/2010/11/23/6029021.aspx
2010年11月23日
J2ME开发的一般步骤
http://blog.csdn.net/zhoufoxcn/archive/2011/06/12/6540223.aspx
2011年06月12日
PowerDesign高级应用
http://zhoufoxcn.blog.51cto.com/792419/166415
2007-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。

你可能感兴趣的文章
python元组遍历
查看>>
python字典用法总结
查看>>
python异常处理
查看>>
python sys.exc_info()详解
查看>>
python中os模块作用
查看>>
ubuntu python subprocess模块执行python脚本
查看>>
python xticks()函数设置X轴方法--刻度、标签
查看>>
HTTP协议原理
查看>>
Python核心模块——urllib模块
查看>>
Python中read()、readline()和readlines()三者间的区别和用法
查看>>
python正则表达式模块re
查看>>
python爬虫总结
查看>>
python网络编程基础--http
查看>>
python 构造http请求对象-Request对象
查看>>
解决Ubuntu16.04更新源时显示“暂时不能解析域名”问题
查看>>
Ubuntu16.04运行清空文件命令时提示权限不够解决方法
查看>>
shell脚本编写笔记
查看>>
rpm、dpkg、yum、apt比较
查看>>
expect详解
查看>>
Ubuntu16.04实现定时免密远程拷贝脚本
查看>>