新手,用Python爬取的大图片部分正常部分损坏,大图链接检查了没有问题,不知道问题出在哪里,或者要怎么调整。

本文介绍了使用Python进行网页爬虫时遇到的问题:从网站抓取的大图片部分正常,部分损坏。作者提供了爬虫代码,并讨论了可能的解决策略,包括检查图片URL、设置请求头、调整超时时间等。
摘要由CSDN通过智能技术生成

import requests as rq
from lxml import etree

def geturl(url):
    try:
        headers={'user-agent':'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Mobile Safari/537.36'}   
        r=rq.get(url,headers=headers,timeout=300)
        r.raise_for_status()
        r.encoding = r.apparent_encoding
        rt=r.text
        s=etree.HTML(rt)
        lianj='//*[@id="main"]/div/ul/li/a/img/@src'
        tu_url=s.xpath(lianj)
        #print(tu_url)
        for j in range(1,len(tu_url),1):
            x_url=str(tu_url[j][0:38]+tu_url[j][43:75]+tu_url[j][85:89])
            #print(x_url)
            tupian=rq.get(x_url,headers=headers,timeout=300).content
            with open('i'+str(i)+'+'+

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Python爬取百度图片并保存的示例代码: ```python # 导入依赖库 import requests import re import os # 设置搜索关键字 keyword = "美食" # 设置图片保存路径 save_path = "./images/" # 构造百度图片搜索的URL url = "https://image.baidu.com/search/index?tn=baiduimage&word={}".format(keyword) # 发送HTTP请求并获取响应 response = requests.get(url) # 使用正则表达式从响应内容中提取图片URL列表 img_urls = re.findall('"objURL":"(.*?)",', response.text, re.S) # 遍历图片URL列表并下载保存图片 for i, img_url in enumerate(img_urls): try: # 发送HTTP请求并获取响应 response = requests.get(img_url, timeout=10) # 设置图片保存路径 img_path = os.path.join(save_path, "{}.jpg".format(i)) # 保存图片 with open(img_path, "wb") as f: f.write(response.content) print("成功下载第{:>3d}张图片!".format(i+1)) except Exception as e: print("下载第{:>3d}张图片失败:{}".format(i+1, e)) ``` 解释一下上述代码的主要步骤: 1. 设置搜索关键字和图片保存路径 2. 构造百度图片搜索的URL 3. 发送HTTP请求并获取响应 4. 使用正则表达式从响应内容中提取图片URL列表 5. 遍历图片URL列表并下载保存图片 需要注意的是,这种方式只是简单的使用正则表达式从响应内容中提取图片URL,而没有使用任何API,因此可能存在一些不稳定性和容易被反爬虫机制封禁的风险。建议在使用时注意合理使用代理、设置请求头等防反措施。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值