当前位置: 首页 > article >正文

python爬虫 爬取站长素材 (图片)(自学6)

安装 :lxml

地址 : Installing lxml

pip install lxml
或者
sudo pip install lxml

 

 

下面开始 写代码  下载 站长素材的图片

 

 

 

import urllib.request

from lxml import etree

import os

def create_request(page):
    if(page == 1):
        url = "https://sc.chinaz.com/tupian/qinglvtupian.html"
    else:
        url = "https://sc.chinaz.com/tupian/qinglvtupian_" + str(page) + '.html'

    # print(url,'ssss')


    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.82 Safari/537.36 Edg/116.0.0.0"
    }

    request = urllib.request.Request(url=url, headers=headers)
    return request



def get_content(request):
    response = urllib.request.urlopen(request)
    content = response.read().decode('utf-8')
    return content


def down_load(content):
    tree = etree.HTML(content)
    srve_list = tree.xpath('//div[@class="item"]/img/@data-original')
    name_list = tree.xpath('//div[@class="item"]/img/@alt')
    # print(name_list , srve_list, 'src')

    for i in range(len(name_list)):
        name = name_list[i]
        src = srve_list[i]
        url = "https:" + src
        print(name,url, 'pinjie')
    #

        # 指定保存图片的文件夹和文件名
        directory = './qinglvtupian'
        if not os.path.exists(directory):
            os.makedirs(directory)  # 如果文件夹不存在,则创建它
        filename = os.path.join(directory, name + '.jpg')

        urllib.request.urlretrieve(url=url, filename=filename)

        # 不存文件夹
        # urllib.request.urlretrieve( url = url , filename= "./qinglvtupian" + name+ '.jpg')

if __name__ == '__main__':
    start_page =  int(input("请输入开始值"))
    end_page =  int(input("请输入结束值"))

    for page in range(start_page, end_page + 1):
        # print(page)
        request =  create_request(page)
        content =   get_content(request)

        down_load(content)

 


http://www.kler.cn/a/519637.html

相关文章:

  • Pyecharts之词云图、面积图与堆叠面积图
  • 一文讲解Java中的重载、重写及里氏替换原则
  • uniapp商城项目之商品详情
  • 在 Windows 系统上,将 Ubuntu 从 C 盘 迁移到 D 盘
  • 家政预约小程序10首先显示服务内容
  • 有关ORM
  • golang命令大全1--概述
  • Maven面试试题及其答案解析
  • 基础项目实战——学生管理系统(c++)
  • 【Elasticsearch】Springboot编写Elasticsearch的RestAPI
  • Vue 响应式渲染 - 模板语法
  • BroadCom-RDMA博通网卡如何进行驱动安装和设置使得对应网口具有RDMA功能以适配RDMA相机
  • 如何实现一个简单的中文错别字高亮系统?
  • 使用python-docx包进行多文件word文字、字符批量替换
  • 【数据分享】1929-2024年全球站点的逐日降水量数据(Shp\Excel格式)
  • springboot使用tomcat浅析
  • 【全栈】SprintBoot+vue3迷你商城(7)
  • 从入门到精通:HttpClient深度剖析与实战指南
  • SpringBoot--基本使用(配置、整合SpringMVC、Druid、Mybatis、基础特性)
  • Maven的继承与聚合特性:大型项目管理的利器