#python:'module' object has no attribute 'urlopen'解决方法

参考“http://blog.sina.com.cn/s/blog_5cf74e410102uxsg.html”

非常简单的一小段代码

[python] view plain copy print?

  1. #!/usr/bin/python  

  2. # -*- coding: UTF-8 -*-  

  3.   

  4. import urllib  

  5.   

  6. def getHtml(url):  

  7.     page = urllib.urlopen(url).read()  

  8.     html=page.read()  

  9.     return html  

  10.   

  11. url="http://tieba.baidu.com/p/4040087257/"  

  12. html=getHtml(url)  

  13.   

  14. print(html)  

报错:

    “AttributeError: 'module' object has no attribute 'urlopen'”

原因是Python3里的urllib模块已经发生改变,此处的urllib都应该改成urllib.request。

[python] view plain copy print?

  1. #!/usr/bin/python  

  2. # -*- coding: UTF-8 -*-  

  3.   

  4. import urllib.request  

  5.   

  6. def getHtml(url):  

  7.     page = urllib.request.urlopen(url)  

  8.     html=page.read()  

  9.     return html  

  10.   

  11. url="http://tieba.baidu.com/p/4040087257/"  

  12. html=getHtml(url)  

  13.   

  14. print(html)  

运行成功!

[python] view plain copy print?

  1. def getImg(html):  

  2.     reg = r'src="(.+?\.jpg)" pic_ext'  

  3.     imgre=re.compile(reg)  

  4.     imglist = re.findall(imgre,html)  

  5.     return imglist  

报错:

   TypeError: can't use a string pattern on a bytes-like object

原因为Python3 findall数据类型用bytes类型,因此在正则表达式前应添加html = html.decode('utf-8')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值