吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 6132|回复: 22
收起左侧

[Python 转载] 输入av号爬取b站弹幕生成词云

  [复制链接]
森岛帆高 发表于 2020-2-13 12:21
本帖最后由 森岛帆高 于 2020-2-13 15:55 编辑

[Python] 纯文本查看 复制代码
import re
import wordcloud
from PIL import Image
import numpy
import requests
import jieba
from lxml import etree
import sys
import threading


# 生成词云图 text传入的文本,name保存文件的名字
def getPic(text, name):
    # 使用numpy.array生成mask,可以让文字显示在有颜色的地方(要传入)
    mask = numpy.array(Image.open("img/timg.jpg"))
    # wordcloud.ImageColorGenerator(mask)可以让文字和图片的颜色保持一致(要传入)
    color_fun = wordcloud.ImageColorGenerator(mask)
    # 创建WordCould对象
    wc = wordcloud.WordCloud(font_path="ttf/SIMYOU.TTF", background_color='white', mask=mask, color_func=color_fun,
                             max_words=160, min_font_size=5, )
    # 向对象传入文本
    wc.generate(text=text)
    # 保存图片
    wc.to_file('词云图/%s弹幕词云.png' % name)


# 根据av号获取html,返回main[0]网页文本和main[1]视频标题
def getHtml(avnum):
    main = []
    headers = {
        'User-Agent': 'Opera/9.80 (Windows NT 6.0) Presto/2.12.388 Version/12.14'
    }
    url = "https://www.bilibili.com/video/av%s" % avnum
    root = requests.get(url, headers=headers)
    html = root.content.decode('utf-8')
    text = root.text
    e = etree.HTML(html).xpath('//*[@id="viewbox_report"]/h1/span/text()')
    try:
        # 这里获取的是etree的啥result对象,要编码再解码
        e = e[0].encode('utf-8').decode('utf-8')
    # av号不正确时退出程序
    except IndexError as error:
        print("你找的视频不存在哦!")
        print("错误信息:" + str(error))
        sys.exit()
    main.append(text)
    main.append(e)
    return main


# http://comment.bilibili.com/->cid-<.xml 根据cid获取视频弹幕信息
# 根据正则表达式获取cid号并返回
def getCid(yy):
    rer = re.compile(r'"cid":\d+')
    a = re.search(pattern=rer, string=yy)
    txt = a.group()
    t = txt.split(':')
    return t[1]


# 获取弹幕(传入cid号)
def getDm(yy):
    url = 'http://comment.bilibili.com/%s.xml' % getCid(yy)
    headers = {
        'User-Agent': 'Opera/9.80 (Windows NT 6.0) Presto/2.12.388 Version/12.14'
    }
    html = requests.get(url, headers=headers).content
    xml = etree.XML(html)
    ds = xml.xpath("//d/text()")
    text = ''
    # 获取弹幕文字合成一个字符串
    for d in ds:
        text += d.encode().decode('utf-8')
    # 使用jieba.lcut切割词语再用空格分隔
    text = ' '.join(jieba.lcut(text))
    return text


# 打开图片
def imgopen():
    img = Image.open('词云图/%s弹幕词云.png' % ma[1])
    img.show()


if __name__ == "__main__":
    av = input('请输入av号:')
    # ma[0]:返回的网页内容,ma[1]:视频标题
    ma = getHtml(av)
    getPic(getDm(yy=ma[0]), ma[1])
    threading.Thread(target=imgopen).start()
    print('视频名称:%s' % ma[1])
    print('词云已生成...')


代码素材链接:https://www.lanzouj.com/i9bc8mh
20200213122243.png

免费评分

参与人数 6吾爱币 +8 热心值 +6 收起 理由
zeorro + 1 + 1 谢谢@Thanks!
苏紫方璇 + 3 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
featmellwo + 1 + 1 用心讨论,共获提升!
iBristlecone + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
敏子ヽ + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
FleTime + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

luanshils 发表于 2020-2-13 12:55
问一个不该问的,什么是AV号,我顺着标题摸进来的,真心发问

这个效果挺好看
kk52140 发表于 2020-2-13 13:05
luanshils 发表于 2020-2-13 12:55
问一个不该问的,什么是AV号,我顺着标题摸进来的,真心发问

这个效果挺好看

AV号是 B站作品的代号  如 AV3514841(瞎打的)   你就可以找到这个作品

免费评分

参与人数 1热心值 +1 收起 理由
luanshils + 1 谢谢@Thanks!

查看全部评分

未知的动力 发表于 2020-2-13 12:48
yleshinimab 发表于 2020-2-13 12:57
虽然没有看懂是些什么,但是还是觉得很厉害
 楼主| 森岛帆高 发表于 2020-2-13 13:07
本帖最后由 森岛帆高 于 2020-2-13 13:11 编辑
luanshils 发表于 2020-2-13 12:55
问一个不该问的,什么是AV号,我顺着标题摸进来的,真心发问

这个效果挺好看

这个

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
luanshils + 1 + 1 谢谢@Thanks!

查看全部评分

白晓生 发表于 2020-2-13 13:13
这波操作还是挺个性的,感谢楼主分享学习了
头像被屏蔽
poemrain 发表于 2020-2-13 13:33
提示: 作者被禁止或删除 内容自动屏蔽
leqaq 发表于 2020-2-13 13:41
luanshils 发表于 2020-2-13 12:55
问一个不该问的,什么是AV号,我顺着标题摸进来的,真心发问

这个效果挺好看

相当于每个视频有一个id值,作为唯一标识符

免费评分

参与人数 1热心值 +1 收起 理由
luanshils + 1 谢谢@Thanks!

查看全部评分

xy0225 发表于 2020-2-13 13:58
不明觉厉
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 11:39

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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