亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

利用Python抓取阿里云盤資源

 更新時(shí)間:2022年02月22日 09:50:12   作者:派森醬  
相對(duì)于百度云盤,阿里云盤的下載不限速,以及大容量空間深受大家的喜愛。本文將通過Python實(shí)現(xiàn)抓取阿里云盤的資源,感興趣的可以學(xué)習(xí)一下

前陣子阿里云盤大火,送了好多的容量空間。而且阿里云盤下載是不限速,這點(diǎn)比百度網(wǎng)盤好太多了。這兩天看到一個(gè)第三方網(wǎng)站可以搜索阿里云盤上的資源,但是它的資源順序不是按時(shí)間排序的。這種情況會(huì)造成排在前面時(shí)間久遠(yuǎn)的資源是一個(gè)已經(jīng)失效的資源。小編這里用 python 抓取后重新排序。

網(wǎng)頁分析

這個(gè)網(wǎng)站有兩個(gè)搜索路線:搜索線路一和搜索線路二,本文章使用的是搜索線路二。

打開控制面板下的網(wǎng)絡(luò),一眼就看到一個(gè) seach.html 的 get 請(qǐng)求。

上面帶了好幾個(gè)參數(shù),四個(gè)關(guān)鍵參數(shù):

  • page:頁數(shù),
  • keyword:搜索的關(guān)鍵字
  • category:文件分類,all(全部),video(視頻),image(圖片),doc(文檔),audio(音頻),zip(壓縮文件),others(其他),腳本中默認(rèn)寫 all
  • search_model:搜索的線路

也是在控制面板中,看出這個(gè)網(wǎng)頁跳轉(zhuǎn)到阿里云盤獲取真實(shí)的的鏈接是在標(biāo)題上面的。用 bs4 解析頁面上的 div(class=resource-item border-dashed-eee) 標(biāo)簽下的 a 標(biāo)簽就能得到跳轉(zhuǎn)網(wǎng)盤的地址,解析 div 下的 p 標(biāo)簽獲取資源日期。

抓取與解析

首先安裝需要的 bs4 第三方庫用于解析頁面。

pip3?install?bs4

下面是抓取解析網(wǎng)頁的腳本代碼,最后按日期降序排序。

import?requests
from?bs4?import?BeautifulSoup
import?string


word?=?input('請(qǐng)輸入要搜索的資源名稱:')
????
headers?=?{
????'User-Agent':?'Mozilla/5.0?(Windows?NT?10.0;?Win64;?x64)?AppleWebKit/537.36?(KHTML,?like?Gecko)?Chrome/96.0.4664.45?Safari/537.36'
}

result_list?=?[]
for?i?in?range(1,?11):
????print('正在搜索第?{}?頁'.format(i))
????params?=?{
????????'page':?i,
????????'keyword':?word,
????????'search_folder_or_file':?0,
????????'is_search_folder_content':?0,
????????'is_search_path_title':?0,
????????'category':?'all',
????????'file_extension':?'all',
????????'search_model':?0
????}
????response_html?=?requests.get('https://www.alipanso.com/search.html',?headers?=?headers,params=params)
????response_data?=?response_html.content.decode()
???
????soup?=?BeautifulSoup(response_data,?"html.parser");
????divs?=?soup.find_all('div',?class_='resource-item?border-dashed-eee')
????
????if?len(divs)?<=?0:
????????break

????for?div?in?divs[1:]:
????????p?=?div.find('p',class_='em')
????????if?p?==?None:
????????????break

????????download_url?=?'https://www.alipanso.com/'?+?div.a['href']
????????date?=?p.text.strip();
????????name?=?div.a.text.strip();
????????result_list.append({'date':date,?'name':name,?'url':download_url})
????
????if?len(result_list)?==?0:
????????break
????
result_list.sort(key=lambda?k:?k.get('date'),reverse=True)

示例結(jié)果:

模板

上面抓取完內(nèi)容后,還需要將內(nèi)容一個(gè)個(gè)復(fù)制到 google 瀏覽器中訪問,有點(diǎn)太麻煩了。要是直接點(diǎn)擊一下能訪問就好了。小編在這里就用 Python 的模板方式寫一個(gè) html 文件。

模板文件小編是用 elements-ui 做的,下面是關(guān)鍵的代碼:

<body>
????<div?id="app">
????????<el-table?:data="table"?style="width:?100%"?:row-class-name="tableRowClassName">
????????????<el-table-column?prop="date"?label="日期"?width="180">?</el-table-column>
????????????<el-table-column?prop="name"?label="名稱"?width="600">?</el-table-column>
????????????<el-table-column?label="鏈接">
??????????????<template?slot-scope="scope">
??????????????<a?:href="'http://'+scope.row.url" rel="external nofollow" 
????????????????target="_blank"
????????????????class="buttonText">{{scope.row.url}}</a>
????????????</template>
????????</el-table>
????</div>

????<script>
??????const?App?=?{
????????data()?{
??????????return?{
??????????????table:?${elements}
????????????
??????????};
????????}
??????};
??????const?app?=?Vue.createApp(App);
??????app.use(ElementPlus);
??????app.mount("#app");
????</script>
??</body>

在 python 中讀取這個(gè)模板文件,并將 ${elements} 關(guān)鍵詞替換為上面的解析結(jié)果。最后生成一個(gè) report.html 文件。

with?open("aliso.html",?encoding='utf-8')?as?t:
????template?=?string.Template(t.read())

final_output?=?template.substitute(elements=result_list)
with?open("report.html",?"w",?encoding='utf-8')?as?output:
????output.write(final_output)

示例結(jié)果:

跳轉(zhuǎn)到阿里云盤界面

完整代碼

aliso.html

<html>
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width,initial-scale=1.0" />
    <script src="https://unpkg.com/vue@next"></script>
    <!-- import CSS -->
    <link rel="stylesheet" >
    <!-- import JavaScript -->
    <script src="https://unpkg.com/element-plus"></script>
    <title>阿里云盤資源</title>
  </head>
  <body>
    <div id="app">

        <el-table :data="table" style="width: 100%" :row-class-name="tableRowClassName">
            <el-table-column prop="date" label="日期" width="180"> </el-table-column>
            <el-table-column prop="name" label="名稱" width="600"> </el-table-column>
            <el-table-column label="鏈接">
              <template v-slot="scope">
              <a :href="scope.row.url"
                target="_blank"
                class="buttonText">{{scope.row.url}}</a>
            </template>
        </el-table>
    </div>

    <script>
      const App = {
        data() {
          return {
              table: ${elements}
            
          };
        }
      };
      const app = Vue.createApp(App);
      app.use(ElementPlus);
      app.mount("#app");
    </script>
  </body>
</html>

aliso.py

# -*- coding: UTF-8 -*-

import requests
from bs4 import BeautifulSoup
import string


word = input('請(qǐng)輸入要搜索的資源名稱:')
    
headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.45 Safari/537.36'
}

result_list = []
for i in range(1, 11):
    print('正在搜索第 {} 頁'.format(i))
    params = {
        'page': i,
        'keyword': word,
        'search_folder_or_file': 0,
        'is_search_folder_content': 0,
        'is_search_path_title': 0,
        'category': 'all',
        'file_extension': 'all',
        'search_model': 2
    }
    response_html = requests.get('https://www.alipanso.com/search.html', headers = headers,params=params)
    response_data = response_html.content.decode()
   
    soup = BeautifulSoup(response_data, "html.parser");
    divs = soup.find_all('div', class_='resource-item border-dashed-eee')
    
    if len(divs) <= 0:
        break

    for div in divs[1:]:
        p = div.find('p',class_='em')
        if p == None:
            break

        download_url = 'https://www.alipanso.com/' + div.a['href']
        date = p.text.strip();
        name = div.a.text.strip();
        result_list.append({'date':date, 'name':name, 'url':download_url})
    
    if len(result_list) == 0:
        break
    
result_list.sort(key=lambda k: k.get('date'),reverse=True)
print(result_list)

with open("aliso.html", encoding='utf-8') as t:
    template = string.Template(t.read())

final_output = template.substitute(elements=result_list)
with open("report.html", "w", encoding='utf-8') as output:
    output.write(final_output)

總結(jié)

用 python 做一些小爬蟲,不僅去掉網(wǎng)站上煩人的廣告,也更加的便利了。

以上就是利用Python抓取阿里云盤資源的詳細(xì)內(nèi)容,更多關(guān)于Python抓取云盤資源的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Python備份Mysql腳本

    Python備份Mysql腳本

    特點(diǎn)是多平臺(tái),一個(gè)腳本內(nèi)可以備份多個(gè)數(shù)據(jù)庫,并分別打包上傳到ftp進(jìn)行備份。調(diào)用了mysqldump及tar來進(jìn)行數(shù)據(jù)庫dump及打包。 具體參數(shù)說明參見源文件
    2008-08-08
  • python腳本實(shí)現(xiàn)xls(xlsx)轉(zhuǎn)成csv

    python腳本實(shí)現(xiàn)xls(xlsx)轉(zhuǎn)成csv

    這篇文章主要介紹了python腳本實(shí)現(xiàn)xls(xlsx)轉(zhuǎn)成csv的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • 六行python代碼的愛心曲線詳解

    六行python代碼的愛心曲線詳解

    這篇文章主要介紹了六行python代碼的愛心曲線詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Python編程在flask中模擬進(jìn)行Restful的CRUD操作

    Python編程在flask中模擬進(jìn)行Restful的CRUD操作

    今天小編就為大家分享一篇關(guān)于Python編程在flask中模擬進(jìn)行Restful的CRUD操作,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • Python調(diào)用Google?Bard的圖文詳解

    Python調(diào)用Google?Bard的圖文詳解

    Google?Bard?是一種開源數(shù)據(jù)可視化和探索工具,可為?開發(fā)人員?提供支持,本文主要為大家介紹了Python調(diào)用Google?Bard的方法,需要的可以參考下
    2023-08-08
  • 使用Python進(jìn)行IPO分析的基本步驟和工具

    使用Python進(jìn)行IPO分析的基本步驟和工具

    在軟件開發(fā)過程中,IPO(Input-Process-Output)分析是一種常用的方法,用于分析軟件系統(tǒng)的輸入、處理和輸出,Python作為一種功能強(qiáng)大的編程語言,提供了許多工具和庫來實(shí)現(xiàn)IPO分析,本文將介紹如何使用Python進(jìn)行IPO分析的基本步驟和常用工具,需要的朋友可以參考下
    2023-12-12
  • Python機(jī)器學(xué)習(xí)利用鳶尾花數(shù)據(jù)繪制ROC和AUC曲線

    Python機(jī)器學(xué)習(xí)利用鳶尾花數(shù)據(jù)繪制ROC和AUC曲線

    這篇文章主要為大家介紹了Python機(jī)器學(xué)習(xí)利用鳶尾花數(shù)據(jù)繪制ROC和AUC曲線實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • python用分?jǐn)?shù)表示矩陣的方法實(shí)例

    python用分?jǐn)?shù)表示矩陣的方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于python如何利用分?jǐn)?shù)表示矩陣的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Django執(zhí)行源生mysql語句實(shí)現(xiàn)過程解析

    Django執(zhí)行源生mysql語句實(shí)現(xiàn)過程解析

    這篇文章主要介紹了Django執(zhí)行源生mysql語句實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • python類共享變量操作

    python類共享變量操作

    這篇文章主要介紹了python類共享變量操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09

最新評(píng)論