- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
针对以下问题,我尝试了多种不同的解决方案,但目前找不到有效的解决方案。我需要从几个网页的元标记中获取一些信息。为此,我发现 lxml 非常有用,因为我还需要使用 xpath 来解析它来查找特定内容。 XPath 在树上可以工作,但是,我有 20% 的网站(总共大约 100 个)无法工作,特别是头似乎坏了。
tree = html.fromstring(htmlfrompage) // using html from lxml package
head_object = tree.head // access to head object from this webpage
在所有这些网站中,访问 head 对象(这只是 xpath 的快捷方式)都会失败并出现相同的错误:
print tree.head
IndexError: list index out of range
因为以下 xpath 失败:
self.xpath('//head|//x:head', namespaces={'x':XHTML_NAMESPACE})[0]
此 xpath 为空,因此访问第一个元素失败。我自己在树中导航, self.xpath('//head') 或 self.xpath('//html/head') 甚至 self.xpath('//body') 是空的。但是如果我尝试直接在文档的任何位置访问元标记:
head = tree.xpath("//meta")
for meta_tag in head:
print meta_tag.text # Just printing something
它有效,所以这意味着元数据没有连接到头部,但它们漂浮在树中的某个地方。反正头也不存在。当然,我可以尝试“修补”这个访问 head 的问题,如果我遇到索引超出范围的异常,我可以导航元数据以找到我正在寻找的内容,但我期望 lxml 修复损坏的 html(正如我在文档中读到的那样) )。
有没有人遇到同样的问题并且可以以更好的方式解决它?
最佳答案
使用requests
我可以很好地加载树:
>>> import requests
>>> from lxml import html
>>> r = requests.get('http://www.lanacion.com.ar/1694725-ciccone-manana-debera-declarar-carosso-donatiello-el-inquilino-de-boudou')
>>> tree = html.fromstring(r.content)
>>> tree.head
<Element head at 0x10681b4c8>
请注意,您想要将字节字符串传递给 html.fromstring()
;不要使用r.text
因为它将改为传递 Unicode。
此外,如果服务器未在 header 中指示编码,requests
回退到 HTTP RFC 默认值,即 text/
的 ISO-8859-1回应。对于这个不正确的具体响应:
>>> r.headers['Content-Type']
'text/html'
>>> r.encoding
'ISO-8859-1'
>>> r.apparent_encoding # make an educated guess
'utf-8'
这意味着r.text
将使用 Latin-1 来解码 UTF-8 数据,导致 Unicode 字符串解码错误,进一步造成困惑。
另一方面,HTML 解析器可以利用 <meta>
header 告诉它要使用什么编码:
>>> tree.find('.//meta').attrib
{'content': 'text/html; charset=utf-8', 'http-equiv': 'Content-Type'}
关于python - lxml 树头和其他一些元素损坏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23896509/
我有以下xml文件 10.10.0.135::3111 10.10.0.130::3111 10.10.0.129::3111 10.
我已经为 PyPy 创建了一个 virtualenv: virtualenv test -p `which pypy` source test/bin/activate 我安装了以下依赖项: sudo
我正在尝试使用 lxml 的 ElementTree etree 在我的 xml 文档中查找特定标签。标签如下所示: 12 我希望使用 etree.find('text:statedAge
在 python 3.5 项目中,我必须读取一些 xml 文件,因此我决定使用 lxml 库。由于我正在阅读文件,因此根据文档执行此操作的最有效方法是使用 lxml.etree.parse(...)
执行 pip install lxml 或 pip install pyquery 会出现此错误: gcc: error trying to exec 'cc1': execvp: No such f
我正在使用下面的代码获取一个部分的所有 html 内容以保存到数据库 el = doc.get_element_by_id('productDescription') lxml.html.tostri
我想以可区分的方式打印出 etree 的树结构(由 html 文档形成)(意味着两个 etree 应该以不同的方式打印出来)。 我所说的结构是指树的“形状”,基本上是指所有标签,但没有属性,也没有文本
谁能解释为什么第一次调用 root.cssselect() 有效,而第二次失败? from lxml.html import fromstring from lxml import etree htm
我收到此错误“ImportError: No module named lxml”,即使确实安装了 LXML。具体来说,它安装在项目的 python Virtualenv 中。最终我正在研究 Pyth
我在 Windows 32 位上使用 Anaconda v4.2 和 Python 3.5,并想使用 lxml etree。我的 Anaconda 发行版包括 lxml 3.6.4,但我的 IDE(P
我有一个脚本,可以从 URL 列表的 XML 文件中提取一些术语。所有 URL 都可以访问 XML 数据。 它在第一次正确打开、解析和提取时工作正常,但随后在过程中被某些 XML 文件中断并出现此错误
我正在使用 mechanize/cookiejar/lxml 来读取页面,它适用于某些页面但不适用于其他页面。我在其中遇到的错误是标题中的错误。我不能在这里发布页面,因为它们不是 SFW,但是有没有办
这是一个基本的问题,我实际上在文档中找不到它:-/ 如下: img = house_tree.xpath('//img[@id="mainphoto"]')[0] 如何获取 的 HTML标记? 我尝
我只想说,这个问题我已经在Pip is already installed: but I am getting no module named lxml看到了并且已经看到关于以非 root 用户身份安
我通过 pip 安装了 lxml 3.3.5。现在我在运行一些 Django 测试时遇到了问题: Traceback (most recent call last): File "manage.p
我有一个 Django 应用程序,其中包含 Tastypie 提供的 RESTFull 服务。我使用 easy_install 安装 lxml 和 defusedxml,这样我就可以使用 xml 而不
我正在使用 lxml etree 创建 xml 或 REST 调用。我有命名空间的问题,因为如果没有正确制定,我会从服务器收到语法错误。 正如您在以下 2 个示例中所看到的,我应该得到例如 ns1、n
我对导航具有 lxml.etree namespace 的 xml 文档感到有些困惑。 .我已经看到了一些关于这个主题的主题( 1 、 2 )以及 lxml docs但仍然没有想出答案。 xml =
由于各种原因,我试图从lxml.html.fromstring()切换到lxml.html.html5parser.document_fromstring()。两者之间的最大区别是,第一个返回lxml
我需要通过向现有元素添加子元素来修改现有的 xml 文件。我使用 lxml 库。 Eric Idle 999-999-999 555-555-555
我是一名优秀的程序员,十分优秀!