Python如何爬取b站热门视频并导入Excel

作者:Yi_warmth 时间:2023-06-20 23:27:44 

代码如下


#encoding:utf-8
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站热门视频并导入Excel

来源:https://www.cnblogs.com/zhouzetian/p/12613930.html

标签:Python,爬取,b站,视频,导入,excel
0
投稿

猜你喜欢

  • Python实现一个自助取数查询工具

    2023-03-03 03:46:16
  • 详解Python3之数据指纹MD5校验与对比

    2023-01-01 03:56:53
  • python利用后缀表达式实现计算器功能

    2022-08-26 03:25:35
  • XML数据查询技术已经成为现今的研究热点

    2008-09-05 17:13:00
  • 解决python 读取excel时 日期变成数字并加.0的问题

    2021-07-11 18:53:41
  • 自定义404错误页面实现自动跳转

    2007-12-10 18:25:00
  • python assert断言的实例用法

    2023-06-24 22:15:42
  • PHP编码转换函数 自动转换字符集支持数组转换

    2024-05-02 17:33:28
  • Python中类型检查的详细介绍

    2022-08-18 16:51:47
  • python 直接赋值和copy的区别详解

    2023-12-14 04:08:49
  • 使用vue.js写一个tab选项卡效果

    2024-04-22 22:23:34
  • 使用Python中的cookielib模拟登录网站

    2022-01-20 08:54:26
  • 用css制作星级投票评分功能

    2008-01-08 21:12:00
  • ASP把长的数字用格式化为货币样式的函数

    2009-09-18 14:49:00
  • Javascript Worker子线程代码实例

    2024-04-17 09:46:16
  • 分享一枚pycharm激活码适用所有pycharm版本我的pycharm2020.2.3激活成功

    2023-10-07 19:07:43
  • 教你使用Python根据模板批量生成docx文档

    2021-12-27 00:35:13
  • 利用pyecharts读取csv并进行数据统计可视化的实现

    2023-07-15 07:18:03
  • 在ASP.NET 2.0中操作数据之六十七:在TableAdapters中使用JOINs

    2024-05-11 09:26:35
  • 浅谈numpy数组的几种排序方式

    2022-04-24 12:48:15
  • asp之家 网络编程 m.aspxhome.com