微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用Ruby从HTML文档中剥离文本

有很多例子说明如何使用 Ruby一个文档中剥离HTML标签,Hpricot和Nokogiri拥有inner_text方法,可以方便快捷地删除所有的HTML.

我想做的是相反的,从HTML文档中删除所有文本,只留下标签及其属性.

我考虑将文档设置inner_html循环到nil,但是真的你必须这样做,因为第一个元素(root)具有整个文档的inner_html,所以理想情况下,我必须从最内在的元素,并将inner_html设置为零,同时向上移动通过祖先.

有没有人知道这样做有效的一个整洁的小技巧?我正在想,正则表达式的可能会做,但可能不如HTML分类器/解析器那么有效.

解决方法

这也是:
doc = Nokogiri::HTML(your_html)
doc.xpath("//text()").remove

原文地址:https://www.jb51.cc/ruby/265999.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐