zoukankan      html  css  js  c++  java
  • spider_爬取斗图啦所有表情包(图片保存)

    """
    爬取斗图吧里面的所有表情包

    知识点总结:
    一、使用requests库进行爬取,随机请求头(网站反爬措施少。挂个请求头足矣)

    二、具体思路:
    1.先爬取所有的图片url,放在列表里
    2.循环遍历url请求这些图片,
    3.将图片进行分类保存
    三、分类保存用到一个知识点,endwith(以***结尾)
    使用这个函数,将jpg,gif,png等不同类型的图片分开
    四、演示案例中,只爬取了前20页。
    五、各个定义的数字变量意思为:
    n=1 网页页数
    num=1 保存图片数

    注:该案例主要是练习
        1.图片的保存,应注意,保存时使用字节流的形式。
        2.书写爬虫代码的逻辑思维。
    """
    from fake_useragent import FakeUserAgent
    import requests
    import re
    import time
    import random
    def getUrls():
    # 将获取到的url列表在放到list这个列表里
    url_list=[]
    n=1
    while True:
    url = f"http://www.doutula.com/article/list/?page={n}"
    headers = {
    "User-Agent":FakeUserAgent().random
    }
    htmlStr = requests.get(url,headers=headers).text
    # print(htmlStr)

    # 定义 提取图片url的正则
    urls = r'data-original="(.*?)"'
    # 编译
    urls = re.compile(urls)
    #正则提取
    urls = re.findall(urls,htmlStr)
    url_list.append(urls)
    print("正在收集第%s页的图片"%n)
    n = n + 1
    # 设置延时
    time.sleep(0.5)
    # 当n=21的时候,爬虫程序停止.为了演示方便只保存前二十页其实共有615页
    if n == 21:
    break
    print(len(url_list))
    return url_list


    # 保存图片
    # 以字节的形式将图片保存
    def download(url_list):
    num = 1
    for urls in url_list:
    for url in urls:
    header={
    "User-Agent":FakeUserAgent().random
    }
    # 因为爬取到的图片有两种,所以写了一个判断条件,分类保存,
    if url.endswith('.jpg'):
    # 保存到本地
    with open('./img/%s.jpg'%num,'wb') as file:
    # 获取到图片 字节
    img = requests.get(url, headers=header)
    file.write(img.content)
    print("正在保存第%s张图片"%num)
    num += 1
    time.sleep(0.3)
    elif url.endswith('.gif'):
    # 保存到本地
    with open('./img/%s.gif' % num, 'wb') as file:
    # 获取到图片 字节
    img = requests.get(url, headers=header)
    file.write(img.content)
    print("正在保存第%s张图片" % num)
    num += 1
    time.sleep(0.3)

    if __name__ == '__main__':
    url_list=getUrls()
    download(url_list)
    人生苦短,我用python!
  • 相关阅读:
    Effective C++ -----条款29:为“异常安全”而努力是值得的
    Effective C++ -----条款28:避免返回handles指向对象内部成分
    Effective C++ -----条款27:尽量少做转型动作
    Effective C++ -----条款26:尽可能延后变量定义式的出现时间
    Effective C++ -----条款25:考虑写出一个不抛异常的swap函数
    Effective C++ -----条款24:若所有参数皆需类型转换,请为此采用non-member函数
    HGE 第一个程序
    Help him http://acm.hdu.edu.cn/showproblem.php?pid=5059
    C 语言实例
    C 语言实例
  • 原文地址:https://www.cnblogs.com/YangQingHong/p/11006257.html
Copyright © 2011-2022 走看看