解决HtmlAgilityPack无法获取form标签子节点的问题

问题描述

今天使用HtmlAgilityPack提取Form表单下的input节点,发现提取的form节点没有子节点,InnerHtml也是为空,起初以为是标签不全导致,后来分析html代码发现不可能是这个问题,提取div标签正常,偏偏form标签有问题,最终从网上找到了答案。

解决方案

在将html转为htmlDoc之前,添加:

1
HtmlNode.ElementsFlags.Remove("form");

就可以正常提取到子节点的内容了,也就是:

1
2
3
4
5
6
HtmlNode.ElementsFlags.Remove("form");
HtmlDocument doc = new HtmlDocument();
doc.LoadHtml(html);

// 提取form表单节点
var formLinks = doc.DocumentNode.SelectNodes("//form[@action]");

参考资料

http://www.crifan.com/htmlagilitypack_html_tag_form_option_no_child_via_sibling_get_innertext/

额外收获

发现了另外一个用户html文档解析的工具SgmlReader,抽空了解一下。

到目前为止已经用过了HtmlAgilityPack和Tidy,感觉还是HtmlAgilityPack用起来方便。

posted @   StanZhai  阅读(1208)  评论(1编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示