色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

python 爬取英雄聯(lián)盟皮膚圖片

瀏覽:6日期:2022-06-18 17:01:41
目錄第一步:獲取js字典第二步:從 js字典中提取到key值生成url列表第三步:從 js字典中提取到value值生成name列表第四步:下載并保存數(shù)據(jù)

一開(kāi)始都是先去《英雄聯(lián)盟》官網(wǎng)找到英雄及皮膚圖片的網(wǎng)址:

URL = r’https://lol.qq.com/data/info-heros.shtml’

從上面網(wǎng)址可以看到所有英雄都在,按下F12查看源代碼,發(fā)現(xiàn)英雄及皮膚圖片并沒(méi)有直接給出,而是隱藏在JS文件中。這時(shí)候需要點(diǎn)開(kāi)Network,找到j(luò)s窗口,刷新網(wǎng)頁(yè),就看到一個(gè)champion.js的選項(xiàng),點(diǎn)擊可以看到一個(gè)字典——里面就包含了所有英雄的名字(英文)以及對(duì)應(yīng)的編號(hào)(如下圖)。

python 爬取英雄聯(lián)盟皮膚圖片

但是只有英雄的名字(英文)以及對(duì)應(yīng)的編號(hào)并不能找到圖片地址,于是回到網(wǎng)頁(yè),隨便點(diǎn)開(kāi)一個(gè)英雄,跳轉(zhuǎn)頁(yè)面后發(fā)現(xiàn)英雄及皮膚的圖片都在,但要下載還需要找到原地址,這是鼠標(biāo)右擊選擇“在新標(biāo)簽頁(yè)中打開(kāi)”,新的網(wǎng)頁(yè)才是圖片的原地址(如下圖)。

python 爬取英雄聯(lián)盟皮膚圖片

圖中紅色框就是我們需要的圖片地址,經(jīng)過(guò)分析知道:每一個(gè)英雄及皮膚的地址只有編號(hào)不一樣(http://ossweb-img.qq.com/images/lol/web201310/skin/big266000.jpg),而該編號(hào)有6位,前3位表示英雄,后三位表示皮膚。剛才找到的js文件中恰好有英雄的編號(hào),而皮膚的編碼可以自己定義,反正每個(gè)英雄皮膚不超過(guò)20個(gè),然后組合起來(lái)就可以了。

圖片地址搞掂都就可以開(kāi)始寫(xiě)程序了:

第一步:獲取js字典

def path_js(url_js): res_js = requests.get(url_js, verify = False).content html_js = res_js.decode('gbk') pat_js = r’'keys':(.*?),'data'’ enc = re.compile(pat_js) list_js = enc.findall(html_js) dict_js = eval(list_js[0]) return dict_js第二步:從 js字典中提取到key值生成url列表

def path_url(dict_js): pic_list = [] for key in dict_js:for i in range(20): xuhao = str(i) if len(xuhao) == 1:num_houxu = '00' + xuhao elif len(xuhao) == 2:num_houxu = '0' + xuhao numStr = key+num_houxu url = r’http://ossweb-img.qq.com/images/lol/web201310/skin/big’+numStr+’.jpg’ pic_list.append(url) print(pic_list) return pic_list第三步:從 js字典中提取到value值生成name列表

def name_pic(dict_js, path): list_filePath = [] for name in dict_js.values():for i in range(20): file_path = path + name + str(i) + ’.jpg’ list_filePath.append(file_path) return list_filePath第四步:下載并保存數(shù)據(jù)

def writing(url_list, list_filePath): try:for i in range(len(url_list)): res = requests.get(url_list[i], verify = False).content with open(list_filePath[i], 'wb') as f:f.write(res) except Exception as e:print('下載圖片出錯(cuò),%s' %(e))return False

執(zhí)行主程序:

if __name__ == ’__main__’: url_js = r’http://lol.qq.com/biz/hero/champion.js’ path = r’./data/’ #圖片存在的文件夾 dict_js = path_js(url_js) url_list = path_url(dict_js) list_filePath = name_pic(dict_js, path) writing(url_list, list_filePath)

運(yùn)行后會(huì)在控制臺(tái)打印出每一張圖片的網(wǎng)址:

python 爬取英雄聯(lián)盟皮膚圖片

在文件夾中可以看到圖片已經(jīng)下載好:

python 爬取英雄聯(lián)盟皮膚圖片

以上就是我的分享,如果有什么不足之處請(qǐng)指出,多交流,謝謝!

以上就是python 爬取英雄聯(lián)盟皮膚圖片的詳細(xì)內(nèi)容,更多關(guān)于python 爬取英雄聯(lián)盟圖片的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 久久精品一区二区免费看 | 国产一级内谢a级高清毛片 国产一级片毛片 | 亚洲欧美7777 | 精品在线视频观看 | 国产一区二区三区高清 | 精品国产免费一区二区三区 | 国产精品二区三区免费播放心 | 精品国产亚洲一区二区三区 | 国产在线观看午夜不卡 | a性片| 欧美操操操 | 欧美高清不卡 | 国产成人在线综合 | 欧美日韩高清不卡一区二区三区 | 美国做受三级的视频播放 | 日本一区二区不卡视频 | 美女黄色在线观看 | 精品一精品国产一级毛片 | 亚州精品一区二区三区 | 在线观看亚洲成人 | 久草在| 在线黄色影院 | 精品国产免费一区二区三区 | 日本三级欧美三级 | 国产成人在线视频免费观看 | 日本高清免费视频色www | 亚洲一区二区中文字幕 | 久久―日本道色综合久久 | 亚洲精品国产三级在线观看 | 午夜免费毛片 | 国产在线一区二区三区欧美 | 国产精品外围在线观看 | 好吊妞国产欧美日韩视频 | 在线视频 中文字幕 | 成年美女黄网站色大 | 夜色伊人| 精品中文字幕久久久久久 | 伊人久爱 | 欧美白人最猛性xxxxx | 欧美成人免费在线观看 | 亚洲国产系列 |