鱼C论坛

 找回密码
 立即注册
查看: 759|回复: 1

第53讲 爬虫

[复制链接]
发表于 2018-7-1 09:49:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
import urllib.request
import chardet

def main():
    i = 0

    with open("urls.txt", 'r') as f:
        urls = f.read().splitlines()

    for each_url in urls:
        response = urllib.request.urlopen(each_url)
        html = response.read()

        encode = chardet.detect(html)['encoding']
        if encode == 'GB2312':
            encode = 'GBK'

        i += 1
        filename = 'url_%d.txt'% i

        with open(filename, 'w', encoding = encode) as each_file:
            each_file.write(html.decode(encode, 'ignore'))

if __name__ == '__main__':
    main()


==================== RESTART: C:/Users/user/Desktop/df.py ====================
Traceback (most recent call last):
  File "C:/Users/user/Desktop/df.py", line 25, in <module>
    main()
  File "C:/Users/user/Desktop/df.py", line 22, in main
    each_file.write(html.decode(encode))
TypeError: decode() argument 1 must be str, not None
>>>
上面是什么原因报错?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-7-1 11:39:27 From FishC Mobile | 显示全部楼层
TypeError: decode() argument 1 must be str, not None
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-7-7 08:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表