鱼C论坛

 找回密码
 立即注册
查看: 3980|回复: 3

[已解决]python课时57爬虫妹子图

[复制链接]
发表于 2018-1-5 19:22:52 | 显示全部楼层 |阅读模式

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

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

x
程序运行后没有图保存到文件夹里,我在里面弄了两个print()发现只是找到了格式为src img=的字符串,没有找到.jpg的字符串,这是怎么回事呢,求教

import urllib.request
import os
#打开一个网页
def url_open(url):
    req = urllib.request.Request(url)
    req.add_header("User-Agent","Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36 QIHU 360SE")
    response = urllib.request.urlopen(req)
    html = response.read()
    return html
   
#先获得最新的页数
def get_page(url):
    html = url_open(url).decode("utf-8")

    a = html.find("current-comment-page") + 23
    b = html.find("]",a)
    return html[a:b]

#获得一页图片存储在列表
def find_imgs(url):
    html = url_open(url).decode("utf-8")
    img_addrs =[]

    a = html.find("img src=")
    while a != -1:
        
        print(a,end="  ")
        b = html.find('.gif',a)
        print(b)

        if b != -1:
            img_addrs.append(html[a+9:b+4])
        else:
            b = a + 9
        a = html.find("img src=",b)

    return img_addrs

#将列表存到文件夹里
def save_imgs(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)

    url = "http://jandan.net/ooxx/"
    page_num = int(get_page(url))-1

    for i in range(pages):
        page_num -= 1
        page_url = url + "page-" + str(page_num)+"#comments"
        img_addrs = find_imgs(page_url)
        save_imgs(folder,img_addrs)

if __name__=="__main__":
    download_mm()
最佳答案
2018-1-5 20:37:10
煎蛋网被爬虫爬太多,现在图片地址是用函数加密的(查看网页源代码会看到加密函数叫jandan_load_img(this)),所以用教程的方法爬不到煎蛋的妹子图url了。可以试试另一个鱼友爬的网站,http://www.gifjia.com/category/neihan/,我刚看了还能爬。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-1-5 19:23:34 | 显示全部楼层
标注颜色的那里每次都是输出-1
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-1-5 20:37:10 | 显示全部楼层    本楼为最佳答案   
煎蛋网被爬虫爬太多,现在图片地址是用函数加密的(查看网页源代码会看到加密函数叫jandan_load_img(this)),所以用教程的方法爬不到煎蛋的妹子图url了。可以试试另一个鱼友爬的网站,http://www.gifjia.com/category/neihan/,我刚看了还能爬。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-1-5 21:15:01 | 显示全部楼层
xiaobinbin 发表于 2018-1-5 20:37
煎蛋网被爬虫爬太多,现在图片地址是用函数加密的(查看网页源代码会看到加密函数叫jandan_load_img(this)) ...

哇原来是这样啊谢谢啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-19 18:50

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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