<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          手把手教你使用Python網(wǎng)絡(luò)爬蟲獲取B站視頻選集內(nèi)容(附源碼)

          共 3138字,需瀏覽 7分鐘

           ·

          2021-09-29 10:03

          ↑ 關(guān)注 + 星標(biāo) ,每天學(xué)Python新技能

          后臺回復(fù)【大禮包】送你Python自學(xué)大禮包

          一、背景引入

              一提到B站,第一印象就是視頻,相信很多小伙伴和我一樣,都想著去利用網(wǎng)絡(luò)爬蟲技術(shù)獲取B站的視頻吧,但是B站視頻其實沒有那么好拿到的,關(guān)于B站的視頻獲取,之前有介紹通過you-get庫進(jìn)行實現(xiàn),感興趣的小伙伴可以看這篇文章:You-Get 就是這么強(qiáng)勢!。

              言歸正傳,經(jīng)常在B站上學(xué)習(xí)的小伙伴們可能經(jīng)常會遇到有的博主連載幾十個,甚至幾百個視頻,尤其像這種編程語言、課程、工具使用等連續(xù)的教程,就會出現(xiàn)選集系列,如下圖所示。

              當(dāng)然這些選集的字段我們?nèi)庋垡彩强梢钥吹玫降?/span>。只是通過程序來實現(xiàn)的話,可能真沒有想象的那么簡單。那么這篇文章的目標(biāo)呢,就是通過Python網(wǎng)絡(luò)爬蟲技術(shù),基于selenium庫,實現(xiàn)視頻選集的獲取。


          二、具體實現(xiàn)

              這篇文章我們用的庫是selenium,這個是一個用于模擬用戶登錄的庫,雖然給人的感覺是慢,但是在網(wǎng)絡(luò)爬蟲領(lǐng)域,這個庫還是用的蠻多的,用它來模擬登錄、獲取數(shù)據(jù)屢試不爽。下面是實現(xiàn)視頻選集采集的所有代碼,歡迎大家親自動手實踐。

          # coding: utf-8from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support import expected_conditions as ECfrom selenium.webdriver.support.wait import WebDriverWait
          class Item: page_num = "" part = "" duration = ""
          def __init__(self, page_num, part, duration): self.page_num = page_num self.part = part self.duration = duration
          def get_second(self): str_list = self.duration.split(":") sum = 0 for i, item in enumerate(str_list): sum += pow(60, len(str_list) - i - 1) * int(item)
          return sum
          def get_bilili_page_items(url): options = webdriver.ChromeOptions() options.add_argument('--headless') # 設(shè)置無界面 options.add_experimental_option('excludeSwitches', ['enable-automation']) # options.add_experimental_option("prefs", {"profile.managed_default_content_settings.images": 2, # "profile.managed_default_content_settings.flash": 0})
          browser = webdriver.Chrome(options=options) # browser = webdriver.PhantomJS() print("正在打開網(wǎng)頁...") browser.get(url)
          print("等待網(wǎng)頁響應(yīng)...") # 需要等一下,直到頁面加載完成 wait = WebDriverWait(browser, 10) wait.until(EC.visibility_of_element_located((By.XPATH, '//*[@class="list-box"]/li/a')))
          print("正在獲取網(wǎng)頁數(shù)據(jù)...") list = browser.find_elements_by_xpath('//*[@class="list-box"]/li') # print(list) itemList = []
          second_sum = 0
          # 2.循環(huán)遍歷出每一條搜索結(jié)果的標(biāo)題 for t in list: # print("t text:",t.text) element = t.find_element_by_tag_name('a') # print("a text:",element.text) arr = element.text.split('\n') print(" ".join(arr)) item = Item(arr[0], arr[1], arr[2]) second_sum += item.get_second() itemList.append(item)
          print("總數(shù)量:", len(itemList)) # browser.page_source
          print("總時長/分鐘:", round(second_sum / 60, 2)) print("總時長/小時:", round(second_sum / 3600.0, 2))
          browser.close()
          return itemList

          get_bilili_page_items("https://www.bilibili.com/video/BV1Eb411u7Fw")

              這里用到的選擇器是xpath,利用視頻示例是B站的《高等數(shù)學(xué)》同濟(jì)版 全程教學(xué)視頻(宋浩老師)視頻選集,大家如果想抓取其他視頻選集的話,只需要更改上述代碼的最后一行的URL鏈接即可。


          三、常見問題

              在運行過程中小伙伴們應(yīng)該會經(jīng)常遇到這個問題,如下圖所示。

              這個是因為谷歌驅(qū)動版本問題導(dǎo)致的,只需要根據(jù)提示,去下載對應(yīng)的驅(qū)動版本即可,驅(qū)動下載鏈接:

          https://chromedriver.storage.googleapis.com/index.html


          - END -


          推薦閱讀

          1. 推薦一個短視頻實戰(zhàn)項目!

          2. 世界第三大瀏覽器正在消亡

          3. 30個名額!網(wǎng)易特邀哈佛外部導(dǎo)師,提供專業(yè)數(shù)據(jù)分析培訓(xùn),費用全免!



          瀏覽 38
          點贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  国产1234区 | 免费成人性爱视频 | 成人午夜A片免费看 | 亚洲成人性 | 操逼网大香蕉 |