Skip to content
This repository has been archived by the owner on Jul 17, 2023. It is now read-only.

Latest commit

 

History

History
302 lines (200 loc) · 9.33 KB

README.md

File metadata and controls

302 lines (200 loc) · 9.33 KB

a


License PYTHON V SPONSOR

Tool-Asoul-Music

A tool for telegram channal delivery,and it can help you to deliver the audio file by asking bilibili api.

Tool-Asoul-Music 是一个使用 Python 编写的自动化的音乐推送程序, 可以 本地运行,交互式机器人部署, 自动抓取 或 手动指定收藏夹Rss地址 提取 BiliBili 视频的音频并推送。 在自动抓取模式下,程序可以打包数据推送备份。项目经过严格模块化重构,便于扩展。

特色

支持四个场景:频道 Rss 自动推送,频道自动搜索推送,Tg交互机器人部署,本地运行。

支持无缝更新。

高度模块化

数据推送备份

支持自动搜索模式

支持部署为Telegram Bot

AES-配置文件关键 Token 加密

支持本地同步收藏夹库

支持Flac元数据标签,自动截取视频封面为音乐封面,并添加作者信息

禁止使用本项目执行商业活动,请注意。

重构自上游项目 github.com/sudoskys/BiliBiliVideoToMusic

部署

环境需求

应当使用 Python 3.8 或更高版本,但是不推荐 3.10 。因为,不能构建加密库。

程序依赖 FFmpeg环境 ,但是默认通过 pip 安装,你也可以使用包管理器。

安装

curl -LO https://raw.githubusercontent.com/sudoskys/Tool-Asoul-Music/main/setup.sh && sh setup.sh

或者

curl -LO https://raw.fastgit.org/sudoskys/Tool-Asoul-Music/main/setup.sh && sh setup.sh

编辑config.yaml

cd Tool-Asoul-Music
sudo apt install nano
nano config.yaml

配置文件说明

USE config.yaml

Lock: False
channalId: -1001741448769
desc: 'music from @somename'
botToken: '8c259c4dc1xxxxxxxxxxxxxxxxxxxxx050b44453a0'
#when you select lock:true,you must use aes to encode all Token! And Dont push your token to github directly. 
onedrive: { statu: True, target: authkey/onedrive.token }
search: { duration: '1', keyword: xxxxxx, order: pubdate, page: '1', search_type: video,  tids_1: '3', tids_2: '28' }
RSS: { statu: True, RssAddressToken: 'https://rssxxxxxxxxxxxxxxxxx' }
DataCallback: { statu: True, UserIdToken: 'bxxxxxxxxxx79' }
ClientBot: { statu: False, owner: 'xxxxxxx' }
Key Value Des
Lock boolen if True then ***Token string will be decode by AESTOOL in addition
channalId -xxxxxxxx USE tg@getidsbot
botToken xxxxxxxx USE tg@BotFather
onedrive xxxxxxxx undo 还没做
search search: { statu: False,data:{ dur....8' }} see PS[1] ,statu 控制开关
RSS xxxxxxxx statu mean start use and,token must be the link from Rsshub #bili-->fav list https://xxxxx.com/bilibili/fav/xxx/xx
DataCallback statu: True, UserIdToken: '' 发送执行的缓存数据(比如服务到期但是没有同步数据see PS[2])。 Token是用户ID或者某些频道ID(需要拉机器人入频道) use tg@getidsbot
ClientBot {statu: False, owner: 'xxxxxxx'} 交互式机器人!可以在线部署 ,owner 为 主人ID
desc some desc 发送消息时的描述

PS

加密配置文件 Token 自助生成

项目的 docs/newToken.md 中提供了生成的实例。

运行

请附带参数

python main.py --p IfYouSetPassword --i True
parser.add_argument('--password', '-p', help='密码,非必要参数,只有配置开启才会使用')
parser.add_argument('--init', '-i', help='是否执行数据初始化,避免大量推送', default=False)

部署推送服务

  • 配置音乐频道推送服务 1.申请一个Bot,向BotFather索取Token 2.使用ID机器人查看目标频道ID 3.将机器人添加至频道并只赋予发消息权限
channalId: -youchannalIDnumberhere

填充/初始化 数据

程序运行会自动初始化数据。

自动搜索模式

配置程序定时运行

对于乌班图,配置如下(不同服务器不同路径呃)

授权

cd Tool-Asoul-Music
chmod 777 main.py
date

crontab 执行

crontab -l
crontab -e

每天5和17执行任务语法

0 5,17 * * * /user/local/python /path/xxx.py

如果脚本中会有涉及读取配置文件或者读写文件的动作,一般定时任务都不会执行. 脚本在执行时,由于是通过crontab去执行的,他的执行目录会变成当前用户的家目录,如果是root,就会在/root/下执行.

所以把执行python的命令放到shell脚本里,然后crontab 定时执行 详见cron.sh

cron用法

chmod +x cron.sh

cron 服务的启动与停止,命令如下 1)service cron start /启动服务/

2)service cron stop /*关闭服务*/

3)service cron restart /*重启服务*/

4)service cron reload /*重新载入配置*/

5)service cron status /*查看crond状态*/ 

使用crontab -e

00 08   * * *  /bin/sh /root/Tool-Asoul-Music/cron.sh

https://blog.csdn.net/xys2333/article/details/112469461 https://blog.csdn.net/GX_1_11_real/article/details/86535942

记得在main文件头部添加类似语句

import sys
sys.path.insert(0, '/root/Tool-Asoul-Music')

记得在cron.sh里面修改密码

部署交互式机器人

后台运行

nohup python3 main.py > output.log 2>&1 &

查看进程

ps -aux|grep python3

终止进程

kill -9  进程号

滥用警告

机器人每分钟在公开群组发送消息的频率不能超过 20/min,否则会被Telegram删除用户账户并销毁资料。

如果你的调用次数过大,哔哩哔哩可能会封禁你的IP,请注意。请对任务列表做相应限制。 同时请注意你的硬盘。

Colab 调试

!rm -f -r /content/*
!git clone https://github.com/sudoskys/Tool-Asoul-Music
!rsync -r /content/Tool-Asoul-Music/* /content/
!python -m pip install --upgrade pip
!pip3 install -r requirements.txt

目录结构描述

.
├── config_exp.yaml # 示例文件
├── cron.sh # cron用
├── data  # 数据目录,智能生成
│       ├── history.yaml
│       └── RssData.json
├── docs # 文档,如何加密
│       └── newToken.md
├── LICENSE
├── main.py  # 运行文件
├── README.md # 自述文件
├── requirements.txt # 依赖说明
├── Runner  # 运行库
│       ├── DataParse.py
│       ├── EventLib.py
│       ├── Network
│       ├── __pycache__
│       └── Task.py
└── setup.sh  # 服务器用


TODO

  • 重构代码结构
  • 优化冗余代码
  • 优化实现流程
  • 支持手动添加
  • 支持同步OD盘
  • 重构 1 次
  • 重构 2 次
  • 重构 3 次

鸣谢

常见问题

https://stackoverflow.com/questions/338768/python-error-importerror-no-module-named

https://blog.csdn.net/qq_35756383/article/details/109135720

Support

如果你感觉这对你有帮助,可以试着我赞助我一点~

s