@ -1,41 +0,0 @@
|
|||||||
|
|
||||||
|
|
||||||
import os
|
|
||||||
from os import path
|
|
||||||
from wordcloud import WordCloud
|
|
||||||
import jieba
|
|
||||||
from imageio.v3 import imread
|
|
||||||
|
|
||||||
def Bulletchat_Wordcloud():
|
|
||||||
try:
|
|
||||||
#获取当前文件路径
|
|
||||||
d = path.dirname(__file__) if "__file__" in locals() else os.getcwd()
|
|
||||||
text = open(path.join(d,r'2028.txt'), 'rb').read()
|
|
||||||
# 设置模板图
|
|
||||||
img_mask = imread(r'm1.png')
|
|
||||||
# 对弹幕进行精确模式分词
|
|
||||||
text_list = jieba.lcut(text,cut_all=False)
|
|
||||||
text_str = ' '.join(text_list)
|
|
||||||
# print(text_str)
|
|
||||||
# 设置中文字体
|
|
||||||
font_path = r'C:\Users\15653\msyh.ttc'
|
|
||||||
# 停止词设置
|
|
||||||
stopwords = set('')
|
|
||||||
stopwords.update(['的','和','又','了','都','是','什么','所以','这','呢','吧','吗','个','呀','嘛','哈'])
|
|
||||||
wc = WordCloud(
|
|
||||||
font_path=font_path,
|
|
||||||
#max_words=500, # 最多词个数
|
|
||||||
#min_font_size=15,
|
|
||||||
#max_font_size=100,
|
|
||||||
mask=img_mask,
|
|
||||||
background_color='white',
|
|
||||||
stopwords=stopwords,
|
|
||||||
colormap='copper'
|
|
||||||
)
|
|
||||||
wc.generate(text_str)
|
|
||||||
wc.to_file(r'outm1.png')
|
|
||||||
except Exception as e:
|
|
||||||
print(f"词云图生成异常: {e}")
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
Bulletchat_Wordcloud()
|
|
@ -1,97 +0,0 @@
|
|||||||
from PIL import Image, ImageDraw, ImageFont
|
|
||||||
import random
|
|
||||||
import imageio
|
|
||||||
import os
|
|
||||||
import re
|
|
||||||
|
|
||||||
# 参数设置
|
|
||||||
WIDTH = 800 # 图片宽度
|
|
||||||
HEIGHT = 600 # 图片高度
|
|
||||||
FONT_SIZE = 20 # 字体大小
|
|
||||||
COL_WIDTH = FONT_SIZE
|
|
||||||
NUM_COLS = WIDTH // COL_WIDTH
|
|
||||||
MAX_TRAIL_LENGTH = 15 # 代码雨最大长度
|
|
||||||
FRAMES_PER_SUBTITLE = 10 # 每条字幕的帧数
|
|
||||||
OUTPUT_GIF = 'code_rain.gif' # 输出 GIF 文件名
|
|
||||||
|
|
||||||
def read_subtitles(filename):
|
|
||||||
"""读取字幕文件"""
|
|
||||||
with open(filename, 'r', encoding='utf-8') as f:
|
|
||||||
subtitles = f.readlines()
|
|
||||||
subtitles = [line.strip() for line in subtitles if line.strip()]
|
|
||||||
return subtitles
|
|
||||||
|
|
||||||
def extract_characters(subtitles):
|
|
||||||
"""从字幕中提取所有出现的字符"""
|
|
||||||
chars_set = set()
|
|
||||||
for line in subtitles:
|
|
||||||
chars_set.update(line)
|
|
||||||
return list(chars_set)
|
|
||||||
|
|
||||||
def main():
|
|
||||||
# 读取字幕
|
|
||||||
subtitles = read_subtitles(r'提取.txt')
|
|
||||||
|
|
||||||
# 提取字符集
|
|
||||||
CHARS = extract_characters(subtitles)
|
|
||||||
# 添加额外的字符(可选)
|
|
||||||
CHARS.extend(list('ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789@#$%^&*()+-'))
|
|
||||||
|
|
||||||
# 加载字体(请确保字体文件存在)
|
|
||||||
font_path = r'msyh.ttc' # 替换为您的字体文件完整路径,确保支持中文
|
|
||||||
|
|
||||||
# 检查字体文件是否存在
|
|
||||||
if not os.path.exists(font_path):
|
|
||||||
print(f"未找到字体文件 '{font_path}'。请提供正确的字体路径。")
|
|
||||||
return
|
|
||||||
|
|
||||||
try:
|
|
||||||
font = ImageFont.truetype(font_path, FONT_SIZE)
|
|
||||||
except OSError:
|
|
||||||
print(f"无法打开字体文件 '{font_path}'。请检查文件是否损坏或权限设置。")
|
|
||||||
return
|
|
||||||
|
|
||||||
# 初始化列的位置
|
|
||||||
column_positions = [random.randint(-HEIGHT, 0) for _ in range(NUM_COLS)]
|
|
||||||
|
|
||||||
frames = []
|
|
||||||
|
|
||||||
for subtitle in subtitles:
|
|
||||||
for _ in range(FRAMES_PER_SUBTITLE):
|
|
||||||
# 创建新图像
|
|
||||||
img = Image.new('RGB', (WIDTH, HEIGHT), color='black')
|
|
||||||
draw = ImageDraw.Draw(img)
|
|
||||||
|
|
||||||
# 绘制代码雨
|
|
||||||
for i in range(NUM_COLS):
|
|
||||||
x = i * COL_WIDTH
|
|
||||||
y = column_positions[i]
|
|
||||||
|
|
||||||
for j in range(MAX_TRAIL_LENGTH):
|
|
||||||
char = random.choice(CHARS)
|
|
||||||
y_pos = y - j * FONT_SIZE
|
|
||||||
if y_pos < 0 or y_pos > HEIGHT:
|
|
||||||
continue
|
|
||||||
green_value = int(255 / MAX_TRAIL_LENGTH * (MAX_TRAIL_LENGTH - j))
|
|
||||||
draw.text((x, y_pos), char, font=font, fill=(0, green_value, 0))
|
|
||||||
|
|
||||||
# 更新列的位置
|
|
||||||
column_positions[i] = (y + FONT_SIZE) % (HEIGHT + FONT_SIZE * MAX_TRAIL_LENGTH)
|
|
||||||
|
|
||||||
# 绘制字幕
|
|
||||||
bbox = draw.textbbox((0, 0), subtitle, font=font)
|
|
||||||
text_width = bbox[2] - bbox[0]
|
|
||||||
text_height = bbox[3] - bbox[1]
|
|
||||||
text_x = (WIDTH - text_width) // 2
|
|
||||||
text_y = HEIGHT - text_height - 10 # 距离底部 10 像素
|
|
||||||
draw.text((text_x, text_y), subtitle, font=font, fill=(255, 255, 255))
|
|
||||||
|
|
||||||
# 添加帧
|
|
||||||
frames.append(img)
|
|
||||||
|
|
||||||
# 保存为 GIF
|
|
||||||
frames[0].save(OUTPUT_GIF, save_all=True, append_images=frames[1:], optimize=False, duration=100, loop=0)
|
|
||||||
print(f"GIF 已保存为 '{OUTPUT_GIF}'")
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
@ -1,62 +0,0 @@
|
|||||||
import requests
|
|
||||||
import json
|
|
||||||
import certifi
|
|
||||||
|
|
||||||
# 请在此处替换为您的 News API 密钥
|
|
||||||
API_KEY = '04c1848491d143f9a9af8a64655167e8'
|
|
||||||
|
|
||||||
# 定义查询参数
|
|
||||||
query = '2024 Paris Olympics AND AI technology'
|
|
||||||
language = 'en'
|
|
||||||
page_size = 100
|
|
||||||
|
|
||||||
# 定义请求 URL 和参数
|
|
||||||
url = 'https://newsapi.org/v2/everything'
|
|
||||||
params = {
|
|
||||||
'q': query,
|
|
||||||
'language': language,
|
|
||||||
'pageSize': page_size,
|
|
||||||
'apiKey': API_KEY
|
|
||||||
}
|
|
||||||
|
|
||||||
def fetch_articles():
|
|
||||||
all_articles = []
|
|
||||||
page = 1
|
|
||||||
while True:
|
|
||||||
params['page'] = page
|
|
||||||
try:
|
|
||||||
response = requests.get(url, params=params, proxies={"http": None, "https": None})
|
|
||||||
|
|
||||||
response.raise_for_status() # 检查HTTP错误
|
|
||||||
data = response.json()
|
|
||||||
|
|
||||||
if data['status'] != 'ok':
|
|
||||||
print(f"获取文章时出错:{data.get('message')}")
|
|
||||||
break
|
|
||||||
|
|
||||||
articles = data.get('articles', [])
|
|
||||||
if not articles:
|
|
||||||
break
|
|
||||||
|
|
||||||
all_articles.extend(articles)
|
|
||||||
print(f"已获取第 {page} 页,共 {len(all_articles)} 篇文章")
|
|
||||||
page += 1
|
|
||||||
|
|
||||||
if len(all_articles) >= 100:
|
|
||||||
break
|
|
||||||
|
|
||||||
except requests.exceptions.RequestException as e:
|
|
||||||
print(f"请求出现异常:{e}")
|
|
||||||
break
|
|
||||||
|
|
||||||
return all_articles
|
|
||||||
|
|
||||||
def save_articles(articles, filename='articles.json'):
|
|
||||||
with open(filename, 'w', encoding='utf-8') as f:
|
|
||||||
json.dump(articles, f, ensure_ascii=False, indent=4)
|
|
||||||
print(f"已将 {len(articles)} 篇文章保存到 {filename}")
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
articles = fetch_articles()
|
|
||||||
if articles:
|
|
||||||
save_articles(articles)
|
|
Before Width: | Height: | Size: 644 KiB |
Before Width: | Height: | Size: 158 KiB |
Before Width: | Height: | Size: 155 KiB |
Before Width: | Height: | Size: 44 MiB |
Before Width: | Height: | Size: 74 KiB |
Before Width: | Height: | Size: 44 KiB |
Before Width: | Height: | Size: 351 KiB |
Before Width: | Height: | Size: 91 KiB |
Before Width: | Height: | Size: 276 KiB |
Before Width: | Height: | Size: 29 KiB |
Before Width: | Height: | Size: 33 KiB |
Before Width: | Height: | Size: 6.0 KiB |