欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python爬取王者榮耀全皮膚的簡單實(shí)現(xiàn)代碼

 更新時(shí)間:2020年01月31日 09:08:21   作者:野狗  
在本篇文章里小編給大家分享的是一篇關(guān)于16行python代碼 爬取王者榮耀全皮膚的知識(shí)點(diǎn)內(nèi)容,有興趣的朋友們學(xué)習(xí)下。

相信現(xiàn)在很多人都喜歡玩王者榮耀這款手游,里面好看的皮膚令人愛不釋手。那么你有沒有想過把王者榮耀高清皮膚設(shè)置為壁紙,像下面這樣

今天就來教大家如何利用python16行代碼,實(shí)現(xiàn)王者榮耀全部高清皮膚的下載。

具體的操作分為兩步:

1. 找到皮膚圖片的地址

2. 下載圖片

1. 尋找皮膚圖片的地址 1. 找到英雄列表

百度"王者榮耀"進(jìn)入官網(wǎng) https://pvp.qq.com/。這里以Goole Chrome瀏覽器為例,在更多工具中選擇開發(fā)者工具,或直接按F12進(jìn)入調(diào)試界面,然后按F5刷新界面

圖中標(biāo)識(shí)的herolist.json文件就是我們所需要的英雄列表,其中包括英雄編號(hào)、英雄名稱、英雄類型、皮膚的名稱等信息,在文件上右擊復(fù)制鏈接,http://pvp.qq.com/web201605/js/herolist.json

接下來驗(yàn)證一下我們尋找的是否正確,代碼1:

import urllib.request
import json
import os

response = urllib.request.urlopen("http://pvp.qq.com/web201605/js/herolist.json")

hero_json = json.loads(response.read())
hero_num = len(hero_json)

print(hero_json)
print("hero_num : " , str(hero_num))

 以上代碼讀取英雄列表并存入hero_json,并獲取英雄數(shù)量,運(yùn)行效果如下圖

  2. 找到英雄皮膚地址

點(diǎn)擊首頁的“游戲資料”標(biāo)簽頁,進(jìn)入新的頁面后隨意點(diǎn)擊一個(gè)英雄頭像進(jìn)入英雄資料頁面,以李白為例。同樣的F12然后F5,將鼠標(biāo)在李白的幾個(gè)皮膚上一次掃過,

來看調(diào)試窗口

 可以看到李白的高清皮膚一共有5個(gè),同樣我們?cè)谝粋€(gè)皮膚上右鍵復(fù)制鏈接得到:

https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/131/131-bigskin-5.jpg

這就是我們想要得到的英雄皮膚鏈接。

分析這個(gè)鏈接我們可以發(fā)現(xiàn),其中‘131'是英雄的編號(hào),最后的'-5'是該英雄的皮膚編號(hào)。到這里,瀏覽器上所需要的信息我們已經(jīng)全部獲得。

2. 下載圖片 1. 英雄有幾個(gè)皮膚

在第一步獲取到的herolist.json文件中有'skin_name'字段,我們只要解析這個(gè)字段就可以獲取皮膚數(shù)量與名稱。測(cè)試代碼接代碼1,代碼2如下:

hero_name = hero_json[0]['cname']
skin_names = hero_json[0]['skin_name'].split('|')
skin_num = len(skin_names)

print('hero_name: ', hero_name)
print('skin_names :', skin_names)
print('skin_num: ' + str(skin_num))

 測(cè)試后的運(yùn)行結(jié)果如下:

  可以看到廉頗一共兩個(gè)皮膚,皮膚名稱分別為:正義爆轟和地獄巖魂。

2. 下載文件

下載文件用到urlretrieve接口,并且考慮兩個(gè)問題:

1. 檢查文件夾是否存在,不存在則創(chuàng)建;

save_dir = 'D:\heroskin\\'
if not os.path.exists(save_dir):
os.mkdir(save_dir)

2. 檢查圖片文件是否存在,如果存在則跳過下載。

if not os.path.exists(save_file_name):
urllib.request.urlretrieve(skin_url, save_file_name)

代碼三如下:

save_dir = 'D:\heroskin\\'
if not os.path.exists(save_dir):
 os.mkdir(save_dir)
 for i in range(hero_num):
  # 獲取英雄皮膚列表
  skin_names = hero_json[i]['skin_name'].split('|')
  for cnt in range(len(skin_names)):
   save_file_name = save_dir + str(hero_json[i]['ename']) + '-' +hero_json[i]['cname']+ '-' +skin_names[cnt] + '.jpg'
   skin_url = 'http://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/'+str(hero_json[i]['ename'])+ '/' +str(hero_json[i]['ename'])+'-bigskin-' + str(cnt+1) +'.jpg'
   print(skin_url)
   if not os.path.exists(save_file_name):
    urllib.request.urlretrieve(skin_url, save_file_name)

總結(jié)

最后完整代碼如下,除去注釋和空行一共16行代碼,實(shí)現(xiàn)了下載王者榮耀全部高清皮膚的功能:

import urllib.request
import json
import os
 
response = urllib.request.urlopen("http://pvp.qq.com/web201605/js/herolist.json")
hero_json = json.loads(response.read())
hero_num = len(hero_json)
save_dir = 'D:\heroskin\\'
if not os.path.exists(save_dir):
 os.mkdir(save_dir)
 for i in range(hero_num):
  # 獲取英雄皮膚列表
  skin_names = hero_json[i]['skin_name'].split('|')
  for cnt in range(len(skin_names)):
   save_file_name = save_dir + str(hero_json[i]['ename']) + '-' +hero_json[i]['cname']+ '-' +skin_names[cnt] + '.jpg'
   skin_url = 'http://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/'+str(hero_json[i]['ename'])+ '/' +str(hero_json[i]['ename'])+'-bigskin-' + str(cnt+1) +'.jpg'
   print(skin_url)
   if not os.path.exists(save_file_name):
    urllib.request.urlretrieve(skin_url, save_file_name)

實(shí)現(xiàn)后的效果如圖所示:

  哈哈,看來掌握一門語言是多么的重要。

以上知識(shí)點(diǎn)不難,大家如果有任何補(bǔ)充可以聯(lián)系腳本之家小編。

相關(guān)文章

  • Python分析特征數(shù)據(jù)類別與預(yù)處理方法速學(xué)

    Python分析特征數(shù)據(jù)類別與預(yù)處理方法速學(xué)

    這篇文章主要為大家介紹了Python分析特征數(shù)據(jù)類別與預(yù)處理方法速學(xué),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • Django ORM判斷查詢結(jié)果是否為空,判斷django中的orm為空實(shí)例

    Django ORM判斷查詢結(jié)果是否為空,判斷django中的orm為空實(shí)例

    這篇文章主要介紹了Django ORM判斷查詢結(jié)果是否為空,判斷django中的orm為空實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • python中列表添加元素的幾種方式(+、append()、extend())

    python中列表添加元素的幾種方式(+、append()、extend())

    本文主要介紹了python中列表添加元素的幾種方式(+、append()、extend()),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Python3.6 之后字典是有序的?

    Python3.6 之后字典是有序的?

    字典數(shù)據(jù)是有序的, 但是這個(gè)序不是由外部控制, 而是內(nèi)部字典定位機(jī)制的序 所以對(duì)外來講, 數(shù)據(jù)本身是無序的 你每次遍歷的順序一樣, 是因?yàn)槊杜e結(jié)果是按內(nèi)部排序輸出 而無序則表示在你無法從外部控制最終的輸出順序,下面我們來學(xué)習(xí)Python字典有序性的相關(guān)資料又當(dāng)怎樣吧
    2021-12-12
  • Python實(shí)現(xiàn)一個(gè)帶權(quán)無回置隨機(jī)抽選函數(shù)的方法

    Python實(shí)現(xiàn)一個(gè)帶權(quán)無回置隨機(jī)抽選函數(shù)的方法

    這篇文章主要介紹了Python實(shí)現(xiàn)一個(gè)帶權(quán)無回置隨機(jī)抽選函數(shù)的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 使用python實(shí)現(xiàn)三維圖可視化

    使用python實(shí)現(xiàn)三維圖可視化

    這篇文章主要介紹了使用python實(shí)現(xiàn)三維圖可視化,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • 詳解Pytorch+PyG實(shí)現(xiàn)GAT過程示例

    詳解Pytorch+PyG實(shí)現(xiàn)GAT過程示例

    這篇文章主要為大家介紹了Pytorch+PyG實(shí)現(xiàn)GAT過程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Python的Flask站點(diǎn)中集成xhEditor文本編輯器的教程

    Python的Flask站點(diǎn)中集成xhEditor文本編輯器的教程

    xhEditor是基于jQuery的Web端文本編輯器,基本的圖片上傳等功能也都帶有,這里我們就來看一下Python的Flask站點(diǎn)中集成xhEditor文本編輯器的教程
    2016-06-06
  • python實(shí)現(xiàn)邏輯回歸的方法示例

    python實(shí)現(xiàn)邏輯回歸的方法示例

    這篇文章主要介紹了python實(shí)現(xiàn)邏輯回歸的方法示例,這是機(jī)器學(xué)習(xí)課程的一個(gè)實(shí)驗(yàn),整理出來共享給大家,需要的朋友可以參考學(xué)習(xí),下來要一起看看吧。
    2017-05-05
  • Python模擬FTP文件服務(wù)器的操作方法

    Python模擬FTP文件服務(wù)器的操作方法

    這篇文章主要介紹了Python_模擬FTP文件服務(wù)器的操作方法,分為服務(wù)端和客戶端,要求可以有多個(gè)客戶端同時(shí)操作。本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-02-02

最新評(píng)論