生成王者榮耀裝備信息Markdown和Excel
王者榮耀的裝備信息列表網(wǎng)址:https://pvp.qq.com/web201605/item.shtml
經(jīng)開發(fā)者工具檢查,裝備數(shù)據(jù)可通過https://pvp.qq.com/web201605/js/item.json接口獲取。
獲取裝備數(shù)據(jù)
采集并整理數(shù)據(jù):
import requests import pandas as pd headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) ' 'Chrome/88.0.4324.104 Safari/537.36 ' } target = 'https://pvp.qq.com/web201605/js/item.json' item_list = requests.get(target, headers=headers).json() item_df = pd.DataFrame(item_list) item_df.sort_values(["item_type", "price", "item_id"], inplace=True) item_df.fillna("", inplace=True) item_df.des1 = item_df.des1.str.replace("?p>", "", regex=True) item_df.des2 = item_df.des2.str.replace("?p>", "", regex=True) item_df
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
查看裝備圖片網(wǎng)址,例如鐵劍的網(wǎng)址為:
https://game.gtimg.cn/images/yxzj/img201606/itemimg/1111.jpg
可以發(fā)現(xiàn)規(guī)律,item_id是圖片的名稱。
多線程下載圖片
import os from concurrent.futures import ThreadPoolExecutor def download_img(item_id): if os.path.exists(f"imgs/{item_id}.jpg"): return imgurl = f"http://game.gtimg.cn/images/yxzj/img201606/itemimg/{item_id}.jpg" res = requests.get(imgurl) with open(f"imgs/{item_id}.jpg", "wb") as f: f.write(res.content) os.makedirs("imgs", exist_ok=True) with ThreadPoolExecutor(max_workers=8) as executor: nums = executor.map(download_img, item_df.item_id)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
幾秒鐘之內(nèi)已經(jīng)下載完全部圖片:
生成Markdown文檔
下面我們生成一下對應的Markdown文檔,首先整理一下數(shù)據(jù):
item_type_dict = {1: '攻擊', 2: '法術(shù)', 3: '防御', 4: '移動', 5: '打野', 7: '游走'} item_ids = item_df.item_id.values item_df.item_id = item_df.item_id.apply( lambda item_id: f"") item_df.item_type = item_df.item_type.map(item_type_dict) item_df.columns = ["圖片", "裝備名稱", "類型", "售價", "總價", "基礎(chǔ)描述", "擴展描述"] item_df
1
2
3
4
5
6
7
按裝備類型分組,生成Markdown文檔:
with open("王者裝備說明.md", "w") as f: for item_type, item_split in item_df.groupby("類型", sort=False): f.write(f"# {item_type}\n") item_split.drop(columns="類型", inplace=True) f.write(item_split.to_markdown(index=False)) f.write("\n\n")
1
2
3
4
5
6
生成的Markdown如下:
不過Markdown的表格無法任意調(diào)整,圖片需要點擊后才會放大,下面我們考慮生成Excel表格:
生成Excel
首先整理數(shù)據(jù):
item_df.圖片 = "" item_df.基礎(chǔ)描述 = item_df.基礎(chǔ)描述.str.replace("
", "\n") item_df.擴展描述 = item_df.擴展描述.str.replace("
", "\n") item_df
1
2
3
4
然后寫出來Excel表:
from openpyxl.drawing.image import Image from openpyxl.styles import Alignment with pd.ExcelWriter("王者裝備說明.xlsx", engine='openpyxl') as writer: item_df.to_excel(writer, sheet_name='裝備說明', index=False) worksheet = writer.sheets['裝備說明'] worksheet.column_dimensions["A"].width = 11 for item_id, (cell,) in zip(item_ids, worksheet.iter_rows(2, None, 1, 1)): worksheet.row_dimensions[cell.row].height = 67 worksheet.add_image(Image(f"imgs/{item_id}.jpg"), f'A{cell.row}') worksheet.column_dimensions["F"].width = 15 worksheet.column_dimensions["G"].width = 35 writer.save()
1
2
3
4
5
6
7
8
9
10
11
12
13
生成結(jié)果如下:
經(jīng)過一番人工調(diào)整后:
大家還可以根據(jù)自己想要的效果生成HTML和Word等等。
Markdown
版權(quán)聲明:本文內(nèi)容由網(wǎng)絡用戶投稿,版權(quán)歸原作者所有,本站不擁有其著作權(quán),亦不承擔相應法律責任。如果您發(fā)現(xiàn)本站中有涉嫌抄襲或描述失實的內(nèi)容,請聯(lián)系我們jiasou666@gmail.com 處理,核實后本網(wǎng)站將在24小時內(nèi)刪除侵權(quán)內(nèi)容。
版權(quán)聲明:本文內(nèi)容由網(wǎng)絡用戶投稿,版權(quán)歸原作者所有,本站不擁有其著作權(quán),亦不承擔相應法律責任。如果您發(fā)現(xiàn)本站中有涉嫌抄襲或描述失實的內(nèi)容,請聯(lián)系我們jiasou666@gmail.com 處理,核實后本網(wǎng)站將在24小時內(nèi)刪除侵權(quán)內(nèi)容。