【bug】当出现特殊换字符时 lxml报错: input conversion failed due to

发布于 2022-09-04 08:14:22 字数 2223 浏览 15 评论 0

错误提示:encoding error : input conversion failed due to
采集一个页面,页面中有无法转码的特殊字符,一般情况下用

.decode('gbk','ignore') 或者.decode('gbk', 'replace') 即可忽略

可是用response.doc()报错且无法获取完整的页面(response.text和response.content 没有问题)

环境版本:win10 32位 pyspider0.3.7
采集的页面无法正确获取编码,所以自己指定了GBK

自己胡乱改了一下源码,问题解决:
打开文件pyspider/libs/response.py
找到:

def etree(self):
        """Returns a lxml object of the response's content that can be selected by xpath"""
        if not hasattr(self, '_elements'):

            try:
                parser = lxml.html.HTMLParser(encoding=self.encoding)
                self._elements = lxml.html.fromstring(self.content, parser=parser)

            except LookupError:
                # lxml would raise LookupError when encoding not supported
                # try fromstring without encoding instead.
                # on windows, unicode is not availabe as encoding for lxml
                self._elements = lxml.html.fromstring(self.content)
        if isinstance(self._elements, lxml.etree._ElementTree):
            self._elements = self._elements.getroot()
        return self._elements

改成:

def etree(self):
        """Returns a lxml object of the response's content that can be selected by xpath"""
        if not hasattr(self, '_elements'):
            try:
                content = self.content.decode(self.encoding, 'replace')
            except LookupError:
                content = self.content.decode('utf-8', 'replace')
                
            try:
                parser = lxml.html.HTMLParser(encoding=self.encoding)
                self._elements = lxml.html.fromstring(content, parser=parser)

            except LookupError:
                # lxml would raise LookupError when encoding not supported
                # try fromstring without encoding instead.
                # on windows, unicode is not availabe as encoding for lxml
                self._elements = lxml.html.fromstring(content)
        if isinstance(self._elements, lxml.etree._ElementTree):
            self._elements = self._elements.getroot()
        return self._elements

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

情归归情 2022-09-11 08:14:22

如果不想改源码,可以 response.content = response.content.decode('gbk', 'replace').encode('gbk')

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文