1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        手把手教你使用Python網絡爬蟲獲取B站視頻選集內容(附源碼)

        共 4040字,需瀏覽 9分鐘

         ·

        2021-09-24 16:16

        點擊上方“Python爬蟲與數據挖掘”,進行關注

        回復“書籍”即可獲贈Python從入門到進階共10本電子書

        位卑未敢忘憂國,事定猶須待闔棺。

            大家好,我是Python進階者。

        前言

            前幾天雪球兄在Python交流群里分享了一個獲取B站視頻選集的Python代碼,小編覺得非常奈斯,這里整理成一篇小文章,分享給大家學習。

            關于雪球兄,大家應該都熟悉了,之前他寫過Python實戰(zhàn)文章,好評如潮,沒來得及看的小伙伴,可以戳這里了:

        盤點常用驗證碼標注和識別項目線上部署三種方式——VUE前端、Java后端和Python后端部署

        Python項目實戰(zhàn)篇——常用驗證碼標注&識別(CNN神經網絡模型訓練/測試/部署)

        Python項目實戰(zhàn)篇——常用驗證碼標注&識別(前端+后端實現高效率數據標注)

        Python項目實戰(zhàn)篇——常用驗證碼標注&識別(數據采集/預處理/字符圖切割)

        Python項目實戰(zhàn)篇——常用驗證碼標注和識別(需求分析和實現思路)

            之前也有給大家分享B站的一些文章,感興趣的話可以看看這個文章,Python網絡爬蟲+數據分析:手把手教你用Python網絡爬蟲獲取B站UP主10萬條數據并用Pandas庫進行趣味數據分析。


        一、背景引入

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

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

            當然這些選集的字段我們肉眼也是可以看得到的。只是通過程序來實現的話,可能真沒有想象的那么簡單。那么這篇文章的目標呢,就是通過Python網絡爬蟲技術,基于selenium庫,實現視頻選集的獲取。


        二、具體實現

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

        # 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') # 設置無界面 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("正在打開網頁...") browser.get(url)
        print("等待網頁響應...") # 需要等一下,直到頁面加載完成 wait = WebDriverWait(browser, 10) wait.until(EC.visibility_of_element_located((By.XPATH, '//*[@class="list-box"]/li/a')))
        print("正在獲取網頁數據...") list = browser.find_elements_by_xpath('//*[@class="list-box"]/li') # print(list) itemList = []
        second_sum = 0
        # 2.循環(huán)遍歷出每一條搜索結果的標題 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("總數量:", 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站的《高等數學》同濟版 全程教學視頻(宋浩老師)視頻選集,大家如果想抓取其他視頻選集的話,只需要更改上述代碼的最后一行的URL鏈接即可。


        三、常見問題

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

            這個是因為谷歌驅動版本問題導致的,只需要根據提示,去下載對應的驅動版本即可,驅動下載鏈接:

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


        四、總結

            我是Python進階者。這篇文章主要給大家介紹了B站視頻選集內容的獲取方法,基于網絡爬蟲,通過selenium庫和xpath選擇器進行實現,并且給大家例舉了常見問題的處理方法。小伙伴們,快快用實踐一下吧!如果在學習過程中,有遇到任何問題,歡迎加我好友,我拉你進Python學習交流群共同探討學習。

        ------------------- End -------------------

        往期精彩文章推薦:

        歡迎大家點贊,留言,轉發(fā),轉載,感謝大家的相伴與支持

        想加入Python學習群請在后臺回復【入群

        萬水千山總是情,點個【在看】行不行

        /今日留言主題/

        隨便說一兩句吧~~

        瀏覽 48
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

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

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            自拍偷拍影音先锋 | 国产精品高潮在线 | 日本韩国三级在线观看 | 久操综合 | 日韩无码AV片 | 91久久香蕉囯产熟女线看蜜桃 | 久久AV秘 一区二区三区水生 | 欧美成人免费精品 | 操逼女人操逼毛片 | 娇妻被交换粗又大又硬动图 |