问题描述

今天使用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用起来方便。

相关文章:

  • 2022-12-23
  • 2021-06-19
  • 2022-12-23
  • 2022-12-23
  • 2022-01-16
  • 2021-06-11
  • 2021-11-12
  • 2021-11-04
猜你喜欢
  • 2021-09-01
  • 2022-12-23
  • 2021-11-14
  • 2021-07-29
  • 2021-09-05
  • 2021-10-26
  • 2021-04-13
相关资源
相似解决方案