中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python如何爬取B站熱門視頻

發布時間:2022-01-14 15:23:38 來源:億速云 閱讀:175 作者:小新 欄目:大數據

這篇文章主要介紹python如何爬取B站熱門視頻,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

本文的文字及圖片來源于網絡,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯系我們以作處理

代碼如下

import requests
from lxml import etree
import xlwt
import os

# 爬取b站熱門視頻信息
def spider():
  video_list = []
  url = "https://www.bilibili.com/ranking?spm_id_from=333.851.b_7072696d61727950616765546162.3"
  html = requests.get(url, headers={"User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36"}).text
  html = etree.HTML(html)
  infolist = html.xpath("//li[@class='rank-item']")
  for item in infolist:
    rank = "".join(item.xpath("./div[@class='num']/text()"))
    video_link = "".join(item.xpath(".//div[@class='info']/a/@href"))
    title = "".join(item.xpath(".//div[@class='info']/a/text()"))
    payinfo = "".join(item.xpath(".//div[@class='detail']/span/text()")).split("萬")
    play = payinfo[0] + "萬"
    comment = payinfo[1]
    if comment.isdigit() == False:
      comment += "萬"
    upname = "".join(item.xpath(".//div[@class='detail']/a/span/text()"))
    uplink = "http://" + "".join(item.xpath(".//div[@class='detail']/a/@href"))
    hot = "".join(item.xpath(".//div[@class='pts']/div/text()"))
    video_list.append({
      'rank': rank,
      'videolink': video_link,
      'title': title,
      'play': play,
      'comment': comment,
      'upname': upname,
      'uplink': uplink,
      'hot': hot
    })
  return video_list


def write_Excel():
  # 將爬取的信息添加到Excel
  video_list = spider()
  workbook = xlwt.Workbook() # 定義表格
  sheet = workbook.add_sheet("b站熱門視頻")  # 添加sheet的name
  xstyle = xlwt.XFStyle()  # 實例化表格樣式對象
  xstyle.alignment.horz = 0x02 # 字體居中
  xstyle.alignment.vert = 0x01
  head = ['視頻名', 'up主','排名', '熱度','播放量','評論數']
  for h in range(len(head)):
    sheet.write(0, h, head[h], xstyle)
  i = 1
  for item in video_list:
    # 向單元格(視頻名)添加該視頻的超鏈接
    if '"' in item["title"]:
      item["title"] = item["title"].split('"')[1]
    title_data = 'HYPERLINK("'+item["videolink"]+'";"'+item["title"]+'")'  # 設置超鏈接
    sheet.col(0).width = int(256 * len(title_data) * 3/5)  # 設置列寬
    sheet.write(i, 0, xlwt.Formula(title_data), xstyle)
    name_data = 'HYPERLINK("'+item["uplink"]+'";"'+item["upname"]+'")'
    sheet.col(1).width = int(256 * len(name_data) * 3/5)
    sheet.write(i, 1, xlwt.Formula(name_data), xstyle)
    sheet.write(i, 2, item["rank"], xstyle)
    sheet.write(i, 3, item["hot"], xstyle)
    sheet.write(i, 4, item["play"], xstyle)
    sheet.write(i, 5, item["comment"], xstyle)
    i += 1
  # 如果文件存在,則將其刪除
  file = "b站熱門視頻信息.xls"
  if os.path.exists(file):
    os.remove(file)
  workbook.save(file)

if __name__ == '__main__':
  write_Excel()

結果展示:

python如何爬取B站熱門視頻

以上是“python如何爬取B站熱門視頻”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

玉龙| 永嘉县| 璧山县| 和硕县| 靖州| 合山市| 顺义区| 小金县| 洮南市| 嵩明县| 淮安市| 大渡口区| 马公市| 五大连池市| 即墨市| 梓潼县| 广西| 宝应县| 安庆市| 兴安县| 盐边县| 贡觉县| 盐池县| 水城县| 章丘市| 池州市| 葫芦岛市| 丹江口市| 永城市| 定襄县| 雅江县| 博爱县| 张家口市| 会泽县| 曲靖市| 田东县| 文安县| 喜德县| 新晃| 聊城市| 关岭|