您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關Python怎么實現bilibili時間長度查詢的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
第一步當然是打開一個視頻
接著第二部右鍵查看源代碼
既然我們是要查找時間,然后我就搜索time相關的,喲!,還真有,其中有個timelength,英語有點基礎的應該也能讀出,這不就是時長的意思。哈哈哈,這也太簡單了,但是又發現高興太早了,這個經過不論是除60還是除3600都無法得到需要的結果,就在這時,突然一個乘法口訣蹦了出來,這個timelength的前幾位除60不就是要的結果嗎,這樣我們就順利找到了
接下來又出現一個問題,這一個頁面的是出來的,但是一共有多少總不能每次都要輸入吧,接下來就繼續分析
看了一下,一共有93集,但是直接搜肯定是不行的,畢竟搜了一下有一百多個。看來要另想出路了。
想到剛才的timelength參數是使用的類似字典類型,那我接按字典的格式搜不也行嗎,
這下行了,搜到的第一個就是,哈哈,我都有些自負了,這也太簡單了,這個問題再次被順利解決了。
最后是代碼,小白寫,大佬勿噴,如有不足還請諒解,源碼已上傳至GitHub
import requests import re import pygame import time header = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) ' 'Chrome/74.0.3729.157 ''Safari/537.36 '} class Bili(object): def __init__(self, url): self.url = url self.max_page = 0 self.the_time = list() self.sum_time = 0 self.b_url = 'https://www.bilibili.com/video/av' + re.search(r'av(\d+)', url).group(1) + '?p=' @staticmethod def get_html(acp_url): try: r = requests.get(acp_url, headers=header) r.raise_for_status() r.encoding = r.apparent_encoding return r.text except Exception as result: print("get_html:", result) return "" def parse_max_page(self): self.max_page = int(re.findall(r'videos":(.+?),', self.get_html(self.url))[0]) def parse_time(self, se_url): text = self.get_html(se_url) single_time = re.findall(r'"timelength":(\d+),', text)[0][:-3] return single_time def get_time(self): for i in range(self.max_page + 1): s_url = self.b_url + str(i) ret = self.parse_time(s_url) self.the_time.append(ret) print("第%d頁 time=%s" % (i, ret)) for each in self.the_time: self.sum_time += int(each) print("sum_time:%.3s h" % str(self.sum_time / 60)) def main(self): self.parse_max_page() self.get_time() if __name__ == '__main__': i_url = input("請輸入鏈接地址[要以+結尾]:") Bili(i_url).main()
感謝各位的閱讀!關于“Python怎么實現bilibili時間長度查詢”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。