首页 编程教程正文

python爬去bilibili cos图片

piaodoo 编程教程 2020-02-22 22:02:00 874 0 python教程

本文来源吾爱破解论坛

#python3运行
import re
import requests
import os
import json


class BiliBili(object,):
    def __init__(self,page_num,dir_name,file_name):
        self.base_url = "https://api.vc.bilibili.com/link_draw/v2/Photo/list?category=cos&type=hot&page_num={}".format(page_num)
        self.headers = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko"}
        self.count = file_name
        self.dir_name = dir_name
       
        #发送请求
    def send_request(self, url):
        resopnse = requests.get(url, headers=self.headers)
        data = resopnse.content.decode()
        json_data = json.loads(data)['data']['items']
        str_data = json.dumps(json_data)
        return str_data
       
        #发送图片链接请求
    def secend_request(self, url):
        resopnse = requests.get(url, headers=self.headers)
        data = resopnse.content
        return data
       
        #对基本url进行解析
    def analysis_url(self, data):
        pattern = re.compile('c": "(.*?)", "i')
        url = re.findall(pattern, data)
        return url
       
        #保存图片信息
    def save_file(self,dir_name,names,data,):
        with open( "{}/".format(dir_name)+ str(names) + '.jpg', 'wb') as f:
            f.write(data)
        #启动
    def run(self):
        try:
            os.mkdir(self.dir_name)
        except:
            pass
      
        data = self.send_request(self.base_url)
        url_list = self.analysis_url(data)
        
        for url in url_list:
            data = self.secend_request(url)
            self. save_file(self.dir_name,self.count,data,)
            print("正在下载第{}个图片".format(self.count))
            self.count += 1
        return "下载完毕"


if __name__ == '__main__':
    while True:
        page_num = int(input("请输入下载的页数"))
        dir_name = input("请输入想要存放的文件夹的名字")
        file_name = int(input("请输入文件的起始名字。仅限纯数字"))
        if type(file_name) == int:
            test = BiliBili(page_num,dir_name,file_name)
            test.run()

版权声明:

本站所有资源均为站长或网友整理自互联网或站长购买自互联网,站长无法分辨资源版权出自何处,所以不承担任何版权以及其他问题带来的法律责任,如有侵权或者其他问题请联系站长删除!站长QQ754403226 谢谢。

有关影视版权:本站只供百度云网盘资源,版权均属于影片公司所有,请在下载后24小时删除,切勿用于商业用途。本站所有资源信息均从互联网搜索而来,本站不对显示的内容承担责任,如您认为本站页面信息侵犯了您的权益,请附上版权证明邮件告知【754403226@qq.com】,在收到邮件后72小时内删除。本文链接:https://www.piaodoo.com/7355.html

搜索