鱼C论坛

 找回密码
 立即注册
查看: 700|回复: 6

大哥们帮忙看看呀,爬取妹子图出现未知bug

[复制链接]
发表于 2020-4-3 17:00:55 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 我龙哟 于 2020-4-3 17:06 编辑

使用requests和bs4爬取meizitu
运行结果:将近一半图片未下载成功
再次运行:未下载成功的图片也有可能下载成功
网络连接无问题,直接浏览器访问图片源地址可以访问
求救……
  1. import requests
  2. import os
  3. from bs4 import BeautifulSoup
  4. import re

  5. def openurl(url):
  6.     try:
  7.         headers = {'Host':'www.meizitu.com','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko'}
  8.         res = requests.get(url,headers=headers)
  9.         res.raise_for_status()
  10.         return res
  11.     except:
  12.         pass

  13. def findimgurl(url):
  14.     res = openurl(url)#print(res.text[:100])
  15.     soup = BeautifulSoup(res.text,"html.parser")
  16.     data = soup.find_all(name='div',attrs={'class':"pic"})
  17.     data2 = []
  18.     for each in data:
  19.         data2.append(each.find_all(name='a',attrs={'target':"_blank"}))
  20.     imgurl = []#print(len(data2))
  21.     for each2 in data2:
  22.         a = re.search(r'src.+jpg',str(each2))#print(a.group(0)[5:])
  23.         imgurl.append(a.group(0)[5:])
  24.     return imgurl#print(imgurl)

  25. def save(url):
  26.     #print(url)
  27.     try:
  28.         path = url.split('/')[-4]+url.split('/')[-3]+url.split('/')[-2]+url.split('/')[-1]         
  29.         if not os.path.exists(path):
  30.             print(path)
  31.             headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko'}
  32.             img = requests.get(url,headers=headers,timeout=30)
  33.             print('状态码为'+str(img.status_code)+',准备下载...')   
  34.             with open(path,"wb") as f:
  35.                 f.write(img.content)
  36.                 f.close()
  37.                 print("保存成功\n")
  38.         else:
  39.             print(path)
  40.             print("文件已存在\n")
  41.     except:
  42.         print("保存出现异常\n")
  43.    
  44. def main():
  45.     i = input('下载页数:')
  46.     floder = 'meizitu_limg'#设置图片存储文件夹
  47.     if not os.path.exists(floder):
  48.         os.mkdir(floder)
  49.         print('\n文件夹'+ floder +'创建完成 ...\n')
  50.     os.chdir(floder)
  51.     for x in range(1,int(i)+1):
  52.         print('\n第'+ str(x) +'页,准备就绪,开始下载 ...\n\n')
  53.         root = '第'+ str(x) +'页'
  54.         if not os.path.exists(root):
  55.             os.mkdir(root)
  56.             print('\n文件夹'+ root +'创建完成 ...\n')
  57.         os.chdir(root)
  58.         url = 'https://www.meizitu.com/a/list_1_'+str(x)+'.html'#第一页https://www.meizitu.com/a/list_1_1.html
  59.         imgurl = findimgurl(url)#print(imgurl)
  60.         print('第'+ str(x) +'页,共查询到'+str(len(imgurl))+'张图片,正在下载中 ...\n\n')
  61.         for eachurl in imgurl:
  62.             save(eachurl)
  63.         print('\n第'+ str(x) +'页图片全部下载完成喽 lalala\n\n')
  64.         os.chdir('..')
  65.         
  66. if __name__ == "__main__":
  67.     main()
复制代码


球球大哥们了,帮忙看看
个人感觉不是timeout的问题,30秒够久了

下面是三种情况输出界面:

2016a0742limg.jpg
状态码为200,准备下载...
保存成功

2016a0741limg.jpg
保存出现异常

2016a0740limg.jpg
文件已存在
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-3 17:53:14 | 显示全部楼层
本帖最后由 老八秘制 于 2020-4-4 07:48 编辑

看看我能不能帮到你
如果觉得有帮助的话,麻烦设个最佳答案,谢谢~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-3 18:25:20 | 显示全部楼层
因为有部分图片能爬成功,初步推测是因为服务器限制频率
你试试time sleep()设一个图片爬取的间隔时间
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-3 20:45:14 | 显示全部楼层
老八秘制 发表于 2020-4-3 17:53
看看我能不能帮到你
如果觉得有帮助的话,麻烦设个最佳答案,谢谢~

链接真隐蔽
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-3 22:54:36 | 显示全部楼层
目前妹子图的反扒,包括,请求头的来源Refer参数,IP请求速度。就这俩,报错你别全try了,你知道是因为什么原因才好排查
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-4 07:48:12 | 显示全部楼层

蓝的不明显么,那我改一下吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-4 10:23:28 | 显示全部楼层
老八秘制 发表于 2020-4-3 17:53
看看我能不能帮到你
如果觉得有帮助的话,麻烦设个最佳答案,谢谢~

我缺的是技术吗,不是网站
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-20 00:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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