gpt4 book ai didi

python - 在 Windows 中使用 BeautifulSoup4、Chardet 和 Python 3.3 解析页面时出错

转载 作者:可可西里 更新时间:2023-11-01 10:37:35 25 4
gpt4 key购买 nike

当我尝试调用 BeautifulSoup(page) 时出现以下错误

Traceback (most recent call last):
File "error.py", line 10, in <module>
soup = BeautifulSoup(page)
File "C:\Python33\lib\site-packages\bs4\__init__.py", line 169, in __init__
self.builder.prepare_markup(markup, from_encoding))
File "C:\Python33\lib\site-packages\bs4\builder\_htmlparser.py", line 136, in
prepare_markup
dammit = UnicodeDammit(markup, try_encodings, is_html=True)
File "C:\Python33\lib\site-packages\bs4\dammit.py", line 223, in __init__
u = self._convert_from(chardet_dammit(self.markup))
File "C:\Python33\lib\site-packages\bs4\dammit.py", line 30, in chardet_dammit

return chardet.detect(s)['encoding']
File "C:\Python33\lib\site-packages\chardet\__init__.py", line 21, in detect
import universaldetector
ImportError: No module named 'universaldetector'

我在 Windows 7 中运行 Python 3.3,我通过下载 .tar.gz 从 setup.py 安装了 bs4。我已经安装了 pip,然后通过执行 pip.exe install chardet 安装了 chardet。我的 chardet 版本是 2.2.1。 Bs4 适用于其他网址。

这是代码

import sys
from urllib.request import urlopen
from bs4 import BeautifulSoup
import re
import chardet

url = "http://www.edgar-online.com/brand/yahoo/search/?cik=1400810"
page = urlopen(url).read()
#print(page)
soup = BeautifulSoup(page)

期待您的回答

最佳答案

我现在遇到这种情况。
不要导入chardet,我也卸载了chardet。
然后构建将通过。
下面的代码是 beautifulsoup 中 dammit.py 库的一部分。
可能是你导入了一个不适合python 3.3的chardet,所以出现这个错误。

try:
# First try the fast C implementation.
# PyPI package: cchardet
import cchardet
def chardet_dammit(s):
return cchardet.detect(s)['encoding']
except ImportError:
try:
# Fall back to the pure Python implementation
# Debian package: python-chardet
# PyPI package: chardet
import chardet
def chardet_dammit(s):
return chardet.detect(s)['encoding']
#import chardet.constants
#chardet.constants._debug = 1
except ImportError:
# No chardet available.
def chardet_dammit(s):
return None

关于python - 在 Windows 中使用 BeautifulSoup4、Chardet 和 Python 3.3 解析页面时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16756842/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com