鱼C论坛

 找回密码
 立即注册
查看: 3787|回复: 4

[已解决]报错 不知道怎么回事

[复制链接]
发表于 2017-6-5 00:20:41 | 显示全部楼层 |阅读模式

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

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

x
import urllib.request
import os
import re
url = "http://jandan.net/ooxx"
def url_open(url):
        req = urllib.request.Request(url)
        req.add_header("User-Agent","Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36")
        response = urllib.request.urlopen(url)
        html = response.read().decode('utf-8')

        return html

def get_page(url):
        a = r'\[\d\d\]'
        b = re.findall(a,url_open(url))
        c = b[:1]
        d = int(c[0].strip('[]'))
        return d

def find_imgs(page_url):
        img_addrs = []
        cc = r'<img src="(.*\.jpg)'
        dd = re.findall(cc,url_open(url))
        img_addrs = ['http:'+x for x in dd]



        return (img_addrs)

       

def save_image(folder,img_addrs):
        for each  in img_addrs:
                filename = each.split('/')[-1]
                with open(filename,'wb') as f:
                        img = url_open(each)
                        f.write(img)


def download_mm(folder = 'OOXX',pages = 10):
        os.mkdir(folder)
        os.chdir(folder)

       
        page_num = int(get_page(url))



最佳答案
2017-6-5 12:47:28
风待葬 发表于 2017-6-5 12:36
AttributeError: 'HTTPResponse' object has no attribute 'decode'

把 html = response.read().decode('utf-8') 去掉 .decode('utf-8')

然后加在 b = re.findall(a, url_open(url)) 中,b = re.findall(a, url_open(url).decode('utf-8'))
1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-6-5 11:53:13 | 显示全部楼层
把 html = response.read().decode('utf-8') 中的 .read() 这个方法去掉
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-6-5 12:36:55 | 显示全部楼层
零度非安全 发表于 2017-6-5 11:53
把 html = response.read().decode('utf-8') 中的 .read() 这个方法去掉

AttributeError: 'HTTPResponse' object has no attribute 'decode'



删除了之后就这样了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-6-5 12:47:28 | 显示全部楼层    本楼为最佳答案   
风待葬 发表于 2017-6-5 12:36
AttributeError: 'HTTPResponse' object has no attribute 'decode'

把 html = response.read().decode('utf-8') 去掉 .decode('utf-8')

然后加在 b = re.findall(a, url_open(url)) 中,b = re.findall(a, url_open(url).decode('utf-8'))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-6-5 13:01:20 | 显示全部楼层
零度非安全 发表于 2017-6-5 12:47
把 html = response.read().decode('utf-8') 去掉 .decode('utf-8')

然后加在 b = re.findall(a, url_ ...

哇  总算   是好了  虽然就出来了几个图片      应该是 有的没有http前缀 有的有http前缀   谢谢  非常感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-30 20:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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