鱼C论坛

 找回密码
 立即注册
查看: 600|回复: 2

[作品展示] b站弹幕密度排序,寻找高能瞬间

[复制链接]
发表于 2019-2-11 15:48:17 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 幽梦三影 于 2019-8-9 12:57 编辑
  1. import random
  2. import re
  3. from collections import Counter

  4. import requests
  5. from lxml import etree


  6. class Danmu_Analyser:
  7.     def __init__(self, url):
  8.         self.url = url
  9.         self.long_time = ""
  10.         self.headers = {
  11.             'User-Agent': "Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1",
  12.             'Referer': 'https://t.bilibili.com/pages/nav/index',
  13.             'Cookie': "你的b站cookie"
  14.         }

  15.     def transform_date(self, t):
  16.         m, s = divmod(int(t), 60)
  17.         h, m = divmod(m, 60)
  18.         result = "%02d:%02d:%02d" % (h, m, s)
  19.         return result

  20.     def get_cid(self):
  21.         text = requests.get(self.url, headers=self.headers).content.decode()
  22.         cid = re.findall(r'cid":(\d+?),', text)
  23.         self.long_time = re.findall(r'"duration":(\d+?),"vid', text)[0]
  24.         return cid

  25.     def get_data(self):
  26.         data = []
  27.         for cid in self.get_cid():
  28.             new_url = "https://comment.bilibili.com/{}.xml".format(cid)
  29.             html = requests.get(new_url).content.decode()
  30.             html = bytes(bytearray(html, encoding='utf-8'))
  31.             select = etree.HTML(html)
  32.             data_dict = {}
  33.             data_dict['danmu'] = select.xpath('//d/text()')
  34.             data_dict['send_time'] = select.xpath('//d/@p')
  35.             data.append(data_dict)
  36.         return data

  37.     def data_deal(self):
  38.         all_data = []
  39.         f = self.get_data()
  40.         danmu = f[0]["danmu"]
  41.         send_time = f[0]["send_time"]
  42.         data = list(zip(danmu, send_time))
  43.         for i in data:
  44.             t = i[1].split(",")[0].split(".")[0]
  45.             t = self.transform_date(t)
  46.             data_dict = {}
  47.             data_dict["send_time"] = t
  48.             data_dict["danmu"] = i[0]
  49.             all_data.append(data_dict)
  50.         return all_data

  51.     def analyse(self):
  52.         data = self.data_deal()
  53.         send_time = [i["send_time"] for i in data]
  54.         all_damu = [{"name": i["danmu"], "value": random.randint(1, 10)} for i in data]

  55.         long_time = [self.transform_date(i) for i in range(int(self.long_time) + 1)]
  56.         s = Counter(send_time)
  57.         r = {}
  58.         for i in long_time:
  59.             if i in s.keys():
  60.                 r[i] = s[i]
  61.             else:
  62.                 r[i] = "0"
  63.         return r, all_damu

  64.     def write_js_file(self):
  65.         html = '''
  66.             <!DOCTYPE html>
  67.         <html lang="en">
  68.         <head>
  69.             <meta charset="UTF-8">
  70.             <title>Title</title>
  71.         </head>
  72.         <body>
  73.             <div id="main" style="width: 1700px;height: 700px;"></div>
  74.             <script src="echarts.js"></script>
  75.         <script>
  76.             let data = ''' + str(self.analyse()[0]) + ''';
  77.             let y = Object.values(data);
  78.             let x = Object.keys(data);
  79.             var myChart = echarts.init(document.getElementById('main'));
  80.             myChart.setOption({
  81.             title: {
  82.                 text: 'bilibili弹幕密度'
  83.             },
  84.             xAxis: {
  85.                 data: x
  86.             },
  87.             yAxis: {},
  88.             series: [{
  89.                 name: '弹幕',
  90.                 type: 'bar',
  91.                 data: y
  92.             }]
  93.         });
  94.         </script>
  95.         </body>
  96.         '''
  97.         with open("./echarts/index.html", "w") as f:
  98.             f.write(html)

  99.     def write_danmu(self):
  100.         html = '''
  101.         <!DOCTYPE html>
  102. <html lang="en">
  103. <head>
  104.     <meta charset="UTF-8">
  105.     <title>词云图</title>
  106.     <script src="./echarts.js"></script>
  107.     <script src="./echarts-wordcloud.js"></script>
  108. </head>
  109. <body>
  110. <div id="main" style="width: 1700px;height: 700px;"></div>
  111. <script type="text/javascript">
  112.     var mychart = echarts.init(document.getElementById("main"));
  113.     var jsonlist = ''' + str(self.analyse()[1]) + ''';
  114.     // 五角星图片
  115.     image = "";
  116.     var maskImage = new Image();
  117.     maskImage.src = image;
  118.     var option = {
  119.         title: {
  120.             text: '词云图',
  121.             left: 'center'
  122.         },
  123.         series: [
  124.             {
  125.                 maskImage:maskImage,
  126.                 type: 'wordCloud',
  127.                 // 设置字符大小范围
  128.                 sizeRange: [6, 66],
  129.                 rotationRange: [-45, 90],
  130.                 textStyle: {
  131.                     normal: {
  132.                         color: function () {
  133.                             return 'rgb(' + [
  134.                                 Math.round(Math.random() * 160),
  135.                                 Math.round(Math.random() * 160),
  136.                                 Math.round(Math.random() * 160)
  137.                             ].join(',') + ')';
  138.                         }
  139.                     }
  140.                 },
  141.                 data: jsonlist
  142.             }
  143.         ]
  144.     };
  145.     maskImage.onload = function(){
  146.         mychart.setOption(option)
  147.     };
  148. </script>

  149. </body>
  150. </html>'''
  151.         with open("./echarts/word.html", "w") as f:
  152.             f.write(html)


  153. if __name__ == "__main__":
  154.     av = input("请输入av号:")
  155.     danmu_analyser = Danmu_Analyser(f"https://m.bilibili.com/video/av{av}.html")
  156.     while 1:
  157.         try:
  158.             danmu_analyser.write_danmu()
  159.             break
  160.         except requests.exceptions.ConnectionError:
  161.             continue
复制代码


                               
登录/注册后可看大图

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-2-11 16:09:39 | 显示全部楼层
阿伟死了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-24 15:58:32 | 显示全部楼层
6666666666666666
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-27 03:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表