鱼C论坛

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

[已解决]问个爬虫问题

[复制链接]
发表于 2021-8-9 14:04:32 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 basketmn 于 2021-8-9 14:06 编辑
  1. import requests
  2. import re
  3. from lxml import etree
  4. url='https://www.qiushibaike.com/video/'
  5. headers={'User-Agent':
  6.         'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:90.0) Gecko/20100101 Firefox/90.0'
  7. }
  8. response=requests.get(url=url,headers=headers)
  9. result=etree.HTML(response.text)
  10. #tupian=re.findall(r'<div class="thumb">.*?<img src="(.*?)" alt=.*?</div>',response.text,re.S)
  11. tupian=result.xpath('//video[@controls="controls"]/source/@src')
  12. print(tupian)
  13. for img_tupian in tupian:
  14.         video_url='https:'+img_tupian
  15.         shipin=requests.get(url=video_url,headers=headers)
  16.         print(shipin)
  17.         with open('.\','wb') as f:
  18.                 f.write(shipin.content)
复制代码

各位大佬,这个被反爬了,返回response [200],怎么解决
最佳答案
2021-8-9 14:18:52
没被反扒啊,response[200],表示请求正常,200是状态码,你这个代码就是open那里有点问题,可以改成
  1. with open('./'+img_tupian.split('/')[-1],'wb')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-9 14:18:52 | 显示全部楼层    本楼为最佳答案   
没被反扒啊,response[200],表示请求正常,200是状态码,你这个代码就是open那里有点问题,可以改成
  1. with open('./'+img_tupian.split('/')[-1],'wb')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-8-9 14:31:35 | 显示全部楼层
本帖最后由 basketmn 于 2021-8-9 14:39 编辑
2012277033 发表于 2021-8-9 14:18
没被反扒啊,response[200],表示请求正常,200是状态码,你这个代码就是open那里有点问题,可以改成


路径没学好啊,要把文件存储再好好看看。
我改了一下还是没东西啊!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-8-9 14:41:02 | 显示全部楼层
2012277033 发表于 2021-8-9 14:18
没被反扒啊,response[200],表示请求正常,200是状态码,你这个代码就是open那里有点问题,可以改成

谢谢大佬!好了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-8-9 14:42:17 | 显示全部楼层
basketmn 发表于 2021-8-9 14:31
路径没学好啊,要把文件存储再好好看看。
我改了一下还是没东西啊!

我这边跑下来正常的,看下你的文件夹是否有写入权限吧
  1. import requests
  2. import re
  3. from lxml import etree
  4. url='https://www.qiushibaike.com/video/'
  5. headers={'User-Agent':
  6.         'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:90.0) Gecko/20100101 Firefox/90.0'
  7. }
  8. response=requests.get(url=url,headers=headers)
  9. result=etree.HTML(response.text)
  10. #tupian=re.findall(r'<div class="thumb">.*?<img src="(.*?)" alt=.*?</div>',response.text,re.S)
  11. tupian=result.xpath('//video[@controls="controls"]/source/@src')
  12. print(tupian)
  13. for img_tupian in tupian:
  14.         video_url='https:'+img_tupian
  15.         shipin=requests.get(url=video_url,headers=headers)
  16.         print(shipin)
  17.         with open('./'+img_tupian.split('/')[-1],'wb') as f:
  18.                 f.write(shipin.content)
复制代码

1.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-8-9 14:49:27 | 显示全部楼层
你代码没问题,保存路径原因
  1. url = 'https://www.qiushibaike.com/video/'
  2. headers = {'User-Agent':
  3.            'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:90.0) Gecko/20100101 Firefox/90.0'
  4.            }
  5. response = requests.get(url=url, headers=headers)
  6. result = etree.HTML(response.text)
  7. #tupian=re.findall(r'<div class="thumb">.*?<img src="(.*?)" alt=.*?</div>',response.text,re.S)
  8. tupian = result.xpath('//video[@controls="controls"]/source/@src')
  9. print(tupian)
  10. for img_tupian in tupian:
  11.     video_url = 'https:'+img_tupian
  12.     shipin = requests.get(url=video_url, headers=headers)
  13.     file_name = img_tupian.split("/")[-1]
  14.     with open(f"./video/{file_name}", 'wb') as f:
  15.         f.write(shipin.content)
  16.         print(f"{file_name} 下载完毕!")
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-8-9 14:50:08 | 显示全部楼层

                               
登录/注册后可看大图
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-20 14:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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