README ¶
bilibili 直播弹幕机
当前支持显示/功能
当前支持显示
以下内容可能过时,点击查看当前支持显示
- 人气
- 天选之人开始
- 天选之人获奖
- 直播间关注提示
- 大航海购买
- 节奏风暴
- 大航海进入
- 弹幕
- 房间信息分区改变
- 禁言
- 礼物
- 封禁
- 下播
- 开播
- SC
- 排行榜
当前支持功能
以下内容可能过时,点击查看功能配置
- 直播流、弹幕回放服务
- 每天自动发送将要过期的银瓜子礼物(默认发送3天内过期的)
- 保持当前已点亮的粉丝牌总是点亮
- 银瓜子自动兑换硬币
- 发进房弹幕(可选有无粉丝牌(可选每日首次发送后不发))
- 每日签到
- 自定义私信
- 自动切换粉丝牌
- 扫码登录(qrcode in webServer and cmd)
- 自定义语音提醒
- GTK弹幕窗
- GTK信息窗
- 营收统计
- 舰长数统计
- 直播流、弹幕保存
- ASS字幕生成
- 节奏提示
- 反射型弹幕机
- 自动型弹幕机
- 相同弹幕合并
- 重复度高弹幕屏蔽
- 弹幕开头字符相同缩减
其他特性
- 使用http代理
- cookie加密
- 弹幕自动重连(30s无响应)
- 直播流开播自动下载、断流再保存、故障转移、移除历史
- 指定弹幕、标题切换重启录制
- 命令行支持房间切换、弹幕发送、表情发送、启停录制、重载弹幕、查看历史记录、查看正在直播的主播、退出房间
- GTK信息窗支持房间切换、弹幕格式化发送、时长统计
- GTK弹幕窗支持自定义人/事件消息停留
说明
本项目使用github action自动构建,构建过程详见yml
保存弹幕至DB
配置文件中添加配置项保存弹幕至db
。参考以下实例:
mysql:
{
"保存弹幕至db": {
"dbname": "mysql",
"url":"root:root@(192.168.31.103:10836)/test",
"字段help":"time.Now().Format(time.DateTime), time.Now().Unix(), item.msg, item.color, item.auth, item.uid, item.roomid",
"create":"create table danmu (created varchar(20), createdunix varchar(20), msg varchar(100), color varchar(20), auth varchar(50), uid varchar(30), roomid varchar(30))",
"insert":"insert into danmu (created, createdunix, msg, color, auth, uid, roomid) values ({Date},{Unix},{Msg},{Color},{Auth},{Uid},{Roomid})"
}
}
sqlite3:
注意:不要并发连接数据库,可能会导致失败
{
"保存弹幕至db": {
"dbname": "sqlite",
"url":"danmu.sqlite3",
"字段help":"time.Now().Format(time.DateTime), time.Now().Unix(), item.msg, item.color, item.auth, item.uid, item.roomid",
"create":"create table danmu (created text, createdunix text, msg text, color text, auth text, uid text, roomid text)",
"insert":"insert into danmu values ({Date},{Unix},{Msg},{Color},{Auth},{Uid},{Roomid})"
}
}
数据实例:
created | createdunix | msg | color | auth | uid | roomid |
---|---|---|---|---|---|---|
2023-04-26 03:20:33 | 1682450433 | 可能走位配合了他的压枪 | #e33fff | 畏未 | 96767379 | 92613 |
2023-04-26 03:20:45 | 1682450445 | =。= | #54eed8 | 青江知暖 | 282800070 | 92613 |
2023-04-26 03:20:52 | 1682450452 | 这不是铁挂吗 | #ffffff | 瑶少溪 | 43048863 | 92613 |
2023-04-26 03:20:55 | 1682450455 | 开个箱? | #58c1de | 修阡宇 | 433678545 | 92613 |
2023-04-26 03:20:59 | 1682450459 | 来了来了 | #00fffc | 我肚子是吃饱了撑大的 | 830140 | 92613 |
指定房间录制回调
配置文件添加了如下配置
{
"指定房间录制回调-help":"当指定roomid的房间结束录制后触发对应的命令,命令执行目录为录播目录,占位符({type}:视频类型),durationS:录制时长超过指定秒数才触发",
"指定房间录制回调":[
{
"roomid":0,
"durationS":60,
"after":["cmd","/c","ffmpeg","-i","0.{type}","-y","-c","copy","1.{type}","1>1.log","2>&1"]
},
{
"roomid":0,
"durationS":60,
"after":["ffmpeg","-i","0.{type}","-y","-c","copy","1.{type}"]
}
]
}
上述例子中演示了windows下使用ffmpeg,这将使得保存的流文件0.mp4 or 0.flv
转为正常的视频1.mp4 or 1.flv
。
注意:命令运行是异步的,如同步执行多个命令,应使用脚本。
性能检查
当配置了Web服务地址
及性能路径
时,运行中的性能信息将可以通过http获取。
例如有如下配置:
config_K_v.json
{
...
"Web服务地址":"0.0.0.0:10000",
"性能路径":"/state"
...
}
此时GET http://127.0.0.1:10000/state
{
"code": 0,
"message": "ok",
"data": {
"currentTime": "2023-03-11 15:49:06", //当前时间
"startTime": "2023-03-11 15:48:26", //启动时间
"state": {
"base": {
"goVersion": "go1.20.1", //编译使用的golang版本
"numGoroutine": 53, //goroutine数量
"reqPoolInUse": 0, //全局请求池-正在使用数量
"reqPoolSum": 2 //全局请求池-总数量
},
"gc": {
"gcAvgS": 6.73, //平均gc间隔 单位秒
"gcCPUFractionPpm": 4.74, //gc的STC耗时占总CPU时间比值 单位百万分之
"lastGC": "2023-03-11 15:49:01", //最后gc时间
"numGC": 6 //总gc数量
},
"mem": { "memInUse": "7.2 MB" } //总使用内存
}
}
}
另外,当配置文件中的debug模式
为true
时,标准包net/http/pprof将在/debug/pprof/
路径可用,从而可以使用go tool pprof
工具进行性能调试。
自定义config_K_v.json
当启动时使用-ckv 路径
,将从此路径(或http地址)加载config_K_v.json并覆盖默认config_K_v.json中的配置项。
使用此配置,可以在有新配置项时,默认使用新配置项而保持之前其他的配置。
表情发送
当demo/config/config_K_v.json
中弹幕_识别表情代码
为true
时,发送特定的文字将发送表情。
在demo/config/config_danmu_official.json
中可找到支持的特殊文字
如,命令行输入点赞回车:
点赞
I: 2022/09/15 02:23:21 弹幕发送 [发送 official_147 至 92613]
赞
danmu.log
I: 2022/09/15 02:23:21 弹幕发送 [发送 official_147 至 92613]
I: 2022/09/15 02:23:23 Msg [qydysky丶 : 赞]
流保存、弹幕ass、弹幕回放文件
以下内容可能过时,点击查看配置
"直播流清晰度-help": "清晰度可选-1:不保存 0:默认 20000:4K 10000:原画 400:蓝光 250:超清 150:高清 80:流畅,无提供所选清晰度时,使用低一档清晰度",
"直播流清晰度": 400,
"直播流类型-help": "flv,fmp4,flvH,fmp4H,带H后缀的为Hevc格式编码",
"直播流类型": "flv",
"直播流保存位置": "./live",
"直播hls流故障转移-help":"true:hls服务器故障时,使用其他",
"直播hls流故障转移": true,
"直播hls流保存为MP4": true,
"仅保存当前直播间流-help": "启用此项,才会保存Ass",
"仅保存当前直播间流": true,
"直播Web服务口":10000,
"直播Web缓冲长度-help":"非负整数,越长直播流延迟越高 内存占用越高",
"直播Web缓冲长度":5,
"直播Web可以发送弹幕":true,
"弹幕回放-help": "仅保存当前直播间流为true时才有效",
"弹幕回放": true,
"ass-help": "只有保存直播流时才考虑生成ass,ass编码默认GB18030(可选utf-8)",
"生成Ass弹幕": true,
"Ass编码": "GB18030",
当直播流类型为fmp4
或fmp4H
时,默认将下载的切片合并保存为mp4
ass编码GB18030支持中文
GB18030
(默认)utf-8
弹幕回放(仅直播流Web服务)
在保存直播流时,如弹幕回放
为true
,则会将会将弹幕同时保存
在直播流Web服务中,点击进入任意一个目录,进行回放,如弹幕回放
为true
,则会将会将弹幕回放出来
直播流回放Web服务
启动Web流服务,为下载的直播流提供局域网内的流服务,提供flv、hls/mp4格式流。
在demo/config/config_K_v.json
中可找到配置项,0.0.0.0
:开放至局域网 127.0.0.1
:仅本机。
"Web服务地址":"0.0.0.0:10000",
"直播Web服务路径":"/web/",
下述路径以上面这个配置作为实例。
直接进入直播Web服务路径,http://127.0.0.1:10000/web/
,将进入由Vue,element-plus创建的简易web目录。
点击目录项,将进入由artplayer、mpegts创建的简易回放界面
特殊
-
路径为
http://127.0.0.1:10000/web/stream?ref=now
当前正在获取的流,播放此链接时进度将保持当前流进度。流格式为fmp4(Hevc)或flv(Hevc)
使用
?ref={目录}
参数来获取流,当为?ref=now
时,为当前直播流 -
火狐不原生支持Hevc格式,因此但模式为
flvH,fmp4H
时,只能播放声音
测试可用项目(测试可连续播放10min+):
- flv-html播放器
- hls-html播放器
- mp4-html播放器
- 客户端播放器
命令行操作
在准备动作完成(T: 2021/03/06 16:22:39 命令行操作 [回车查看帮助]
)后,输入回车将显示帮助
切换房间->输入' 数字'回车
发送弹幕->输入'字符串'回车
查看直播中主播->输入' liv'回车
重载弹幕->输入' reload'回车
搜索主播->输入' sea关键词'回车
房间信息->输入' room'回车
开始结束录制->输入' rec'回车
退出当前房间->输入' exit'回车
其他输出隔断不影响
用例:
- 直播间切换
his
T: 2023/02/01 02:34:00 命令行操作 [指令( his)]
T: 2023/02/01 02:34:00 api 历史直播主播 [获取中]
T: 2023/02/01 02:34:00 api 历史直播主播 [完成]
0 ☁ 少年Pi(92613)
MC
1 C酱です(47867)
阿C今天又在玩什么捏
2 逍遥散人(1017)
日常闲聊 麻将上分训练
3 烤鱼子Official(22259479)
!!!!新年快乐!!!!
4 ☁ Asaki大人(6154037)
开心鸭鸭杀
5 观察者网(948391)
一周军情观察:海的那边是敌人
6 一米八的坤儿(4350043)
单排下饭主播
7 数字猫(3839755)
石村号上的朋友真是热情好客
8 ☁ 环球时报(796281)
家乡的风景 家乡的年
9 千鈴鳴_Official(26724557)
【B限】原神やるぞおおおお【千鈴鳴】
回复' to(序号)'进入直播间
3 x 9
满脑子都是小c
to4
T: 2023/02/01 02:34:07 命令行操作 [指令( to4)]
I: 2023/02/01 02:34:07 bilidanmu [停止,等待服务器断开连接]
I: 2023/02/01 02:34:07 bilidanmu [服务器连接关闭]
I: 2023/02/01 02:34:07 直播流保存 [正在等待下载完成...]
T: 2023/02/01 02:34:08 弹幕回放 [停止]
I: 2023/02/01 02:34:08 直播流保存 [结束录制(92613)]
T: 2023/02/01 02:34:09 功能 弹幕合并 [房间更新: 6154037]
T: 2023/02/01 02:34:09 bilidanmu [准备]
T: 2023/02/01 02:34:09 api IsConnected [已连接]
I: 2023/02/01 02:34:10 bilidanmu [连接到房间 6154037]
I: 2023/02/01 02:34:16 api 切换粉丝牌 [无主播粉丝牌]
I: 2023/02/01 02:34:17 bilidanmu [直播中]
T: 2023/02/01 02:34:17 bilidanmu [连接 wss://hw-sh-live-comet-03.chat.bilibili.com/sub]
I: 2023/02/01 02:34:17 bilidanmu [已连接到房间 Asaki大人 ( 6154037 )]
I: 2023/02/01 02:34:17 bilidanmu [开心鸭鸭杀]
T: 2023/02/01 02:34:18 bilidanmu [获取人气]
120
I: 2021/03/06 16:21:35 命令行操作 [进入 120]
- 发送弹幕
1
I: 2021/03/06 16:21:17 弹幕发送 [发送 1 至 7734200]
- 查看房间信息
room
T: 2023/02/01 02:35:38 命令行操作 [指令( room)]
当前直播间(6154037)信息
Asaki大人 开心鸭鸭杀 直播中
已直播时长: 08:12:18
营收: ¥0.00
舰长数: 1287
分区排行: 人气榜 2 人气: 2049772 观看人数: 278848 在线人数: 10000
直播Web服务: http://0.0.0.0:10000
正在录制的房间:
Asaki大人(6154037) 开心鸭鸭杀
输入` rec` 来启停当前房间录制
还支持登录、搜索主播直播间、查看历史记录、查看关注的直播间、保存直播流等功能
cookie加密
保护cookie.txt
在demo/config/config_K_v.json
中可找到配置项
"cookie加密公钥":"public.pem",
"cookie解密私钥":"private.pem"
- 当配置了公钥路径后,cookie将被加密(若公钥无效,将会导致cookie无法储存)。若未配置私钥路径,则每次启动都会要求输入私钥路径。(若私钥无效,将会导致cookie被清除)
- 当未配置公钥路径(空字符串),cookie将明文储存。
- 默认使用了
demo/
下的(public.pem)(private.pem)进行加密,使用时注意自行生成公私钥并按照上述说明使用
注意,每次更换设置(设置或未设置公钥),cookie会失效。
附:创建公(public.pem)私(private.pem)钥
openssl genrsa -out private.pem 2048
openssl rsa -in private.pem -pubout -out public.pem
私信
在登录后,可以使用私信
私信配置在demo/config/config_K_v.json
有说明
语音
调用tts默认使用ffplay,安装ffmpeg
或使用其他程序:可在demo/config/config_K_v.json
中编辑调用的程序及附加选项
config_K_v.json
默认
"TTS_使用程序路径":"ffplay",
"TTS_使用程序参数":"-autoexit -nodisp"
使用mpv
"TTS_使用程序路径":"mpv",
"TTS_使用程序参数":"--no-video"
使用potplayer(例程序位置D:\potplayer\PotPlayerMini64.exe)
"TTS_使用程序路径":"D:\\potplayer\\PotPlayerMini64.exe",
"TTS_使用程序参数":"/current /autoplay"
release默认编译tts
总开关,自定义响应的事件可在demo/config/config_tts.json
中编辑。{}为传递过来的变量,将会按设定替换。最后未使用的{}会全部删除。下例:ABC购买 1个月舰长
。
...
"0buyguide-help": "大航海 {username}:用户 {op_name}:购买方式 {role_name}:大航海类型 {num}:个数 {unit}:时间单位",
"0buyguide": "{username}{op_name} {num}个{unit}{role_name}",
...
特别说明的,下面结构为全局替换。
"replace":{
"?":"问号",
"?":"问号"
}
在demo/config/config_K_v.json
中可选使用的服务api
"TTS_服务器-help": "baidu:百度翻译合成 youdao:有道TTS",
"TTS_服务器": "youdao",
"TTS_服务器_youdaoId": "",
"TTS_服务器_youdaoKey": "",
使用有道则需要Id和Key。
"TTS_服务器_youdaoId": "7xxxxxxxxxxxxxxa",
"TTS_服务器_youdaoKey": "yxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxP",
使用讯飞则需要应用Id、Key、Secret。可设置发音人。
"TTS_服务器_xfId": "6xxxxxxb",
"TTS_服务器_xfKey": "4xxxxxxxx9",
"TTS_服务器_xfSecret": "YxxxxxxxBh",
"TTS_服务器_xfVoice-help": "讯飞发音人 xiaoyan:小燕甜美女声 aisjiuxu:许久亲切男声 aisxping:小萍知性女声 aisjinger:小婧亲切女声 aisbabyxu:许小宝可爱童声 random:随机",
"TTS_服务器_xfVoice": "random",
弹幕窗
构建gtk需要gtk3,先行安装gtk release 由于某些原因,Linux默认不编译gtk界面 Windows默认不编译
编译命令
cd demo
go build -v -tags `gtk` -o demo.exe -i main.go
弹幕处理/响应
默认开启了
- 反射弹幕机
启动时加载,当弹幕内容与demo/config_auto_reply.json
中所设键名相同时,在登录的情况下,会自动发送对应值的弹幕
- 相同合并
当短时间存在大量完全相同的弹幕时,他们将合并显示。
- 更少弹幕
过滤掉自身重复度及最近弹幕重复度高的弹幕
- 更短弹幕
当与上条弹幕具有相同开头的开头时,重复的部分会用...替代
仅对显示效果进行处理,而不处理输出到日志。更多设置见demo/config/config_F.json
运行
方法
- 预先编译
clone/下载本项目。进入demo
目录(文件夹),运行:
linux: CGO_ENABLED=0 go build .
windows: set CGO_ENABLED=0;go build .
再运行生成的demo.exe
或demo
- 即时编译
clone/下载本项目。进入demo
目录(文件夹),运行:
linux: CGO_ENABLED=0 go run . [-r 房间ID] [-ckv 自定义config_K_v.json]
windows: set CGO_ENABLED=0;go run . [-r 房间ID] [-ckv 自定义config_K_v.json]
- docker部署
经测试可以部署到ubuntu
镜像上,注意首先得更新ca
apt-get update && apt-get install -y ca-certificates openssl
如果你日常使用windows,但在ubuntu运行,那还需先编译linux版本
clone/下载本项目。进入demo
目录(文件夹),运行:
set GOOS=linux
set CGO_ENABLED=0
go build .
注意实际使用时,在config_K_v.json
关闭tts
等需要关闭界面及音频的功能,配置好录播存放位置,做好直播流服务的端口映射
- github编译
前往releases页下载对应系统版本。解压后进入demo
目录(文件夹),运行demo.run
(demo.exe
)。
./demo.run [-r 房间ID] [-ckv 自定义config_K_v.json]
./demo.exe [-r 房间ID] [-ckv 自定义config_K_v.json]
注意事项
- 其中[]内的内容为可选项
- 法1,2,3建议使用最新提交
- 弹幕及礼物会记录于danmu.log中
- 部分功能(如签到、发送弹幕、获取原画等)需要在
demo
目录(文件夹)下放置cookie.txt
才可用 或 运行时按提示使用扫码登录成功后才可用(登录信息会保存在demo/cookie.txt
中) - 在golang1.20+,由于某些原因,你可能需要在构建时添加
CGO_ENABLED=0
- 由于通常是发现功能不正常时,才会检查b站是否更新,又因日常录播并不会使用到全部功能,所以并不能确保全部功能都能正常运行
关于更新版本v0.{y}.{z}
- 当bilibili停止服务时,将会发布v1版本。
- 当对配置文件发生不兼容的改动(删减原来有效、修改有效项的含义)时,将会发布v0.{y+1}.0版。更新前,你需要关注更新说明,以确认变动的配置项的影响。
- 当对配置文件发生兼容的改动(修复、新增功能)时,将会发布v0.{y}.{z+1}版。通常只需要覆盖主体
demo.run
(demo.exe
)即可更新。 - 另外
releases
页面中,Pre-release
表示此版本为尚未经过验证的版本,或存在重大bug,Latest
表示此版本经过验证,不存在明显的重大bug。
效果展示
以下内容可能过时,以实际运行为准
命令窗口(以下为截取)
//启动
qydysky@DESKTOP-5CV1EFA:~/程序/git/go/src/github.com/qydysky/bili_danmu/demo$ go run -tags "gtk" main.go -r 21320551
I: 2021/02/18 20:33:09 api 小心心加密 [如需加密,会自动打开 http://127.0.0.1:33673]
I: 2021/02/18 20:33:09 api 小心心加密 [启动]
PID:14544
房间号: 21320551
T: 2021/02/18 20:33:09 api 新建 [ok]
T: 2021/02/18 20:33:09 api 获取房号 [获取房号]
T: 2021/02/18 20:33:10 api LIVE_BUVID [获取LIVE_BUVID]
I: 2021/02/18 20:33:10 api LIVE_BUVID [存在]
T: 2021/02/18 20:33:11 api 获取Token [ok]
I: 2021/02/18 20:33:13 api 获取直播流 [轮播中]
T: 2021/02/18 20:33:13 api 银瓜子=>硬币 [银瓜子=>硬币]
I: 2021/02/18 20:33:15 api 银瓜子=>硬币 [现在有银瓜子 540 个]
W: 2021/02/18 20:33:15 api 银瓜子=>硬币 [当前银瓜子数量不足]
T: 2021/02/18 20:33:15 api 签到 [签到]
I: 2021/02/18 20:33:19 api 获取客户版本 [api version 2.6.25]
I: 2021/02/18 20:33:21 api 获取热门榜 [热门榜: 虚拟主播 50+]
I: 2021/02/18 20:33:23 bilidanmu Demo [连接到房间 21320551]
I: 2021/02/18 20:33:23 bilidanmu Demo [连接 wss://tx-bj-live-comet-02.chat.bilibili.com/sub]
T: 2021/02/18 20:33:23 api 小心心 [获取小心心]
I: 2021/02/18 20:33:23 bilidanmu Demo [已连接到房间 乙女音Official ( 21320551 )]
I: 2021/02/18 20:33:23 bilidanmu Demo [【b限】学《巴啦啦小魔仙》]
I: 2021/02/18 20:33:24 bilidanmu Demo [获取人气]
T: 2021/02/18 20:33:25 api 礼物列表 [获取礼物列表]
I: 2021/02/18 20:33:27 api 获取舰长数 [舰长数获取成功 471]
I: 2021/02/18 20:33:27 弹幕发送 [发送 至 21320551]
I: 2021/02/18 20:33:27 功能 [营收 ¥0.00]
I: 2021/02/18 20:33:29 api 礼物列表 [成功]
I: 2021/02/18 20:33:29 api 小心心 [今天小心心已满!]
//普通弹幕
老鸡捉小鹰
你快扒拉他
你这好像是补刀
吓人
//大航海
>>> 欢迎舰长 Mana_单推... 进入直播间
//礼物
====
超级角击 投喂 1 个 摩天轮
====
//同字符串合并
7 x 原神公测B服冲冲冲
//同字符忽略
原神公测B站冲冲冲
...B服冲冲冲
//SC
====
SC: 凪穗
有了OTO能量,我们才能够坚强,prprpr
OTOエネルギーがあれば、私たちは強くなれる。prprprpr
====
//gtk的弹幕格式化发送
2020/11/20 15:39:57 弹幕格式已设置为 [{D}]
INFO: 2020/11/20 15:40:05 [弹幕发送] [发送 [就是这样] 至 394988]
[就是这样]
INFO: 2020/11/20 15:40:15 [弹幕发送] [发送 [你知道么] 至 394988]
[你知道么]
2020/11/20 15:42:38 弹幕长度大于20,不做格式处理
INFO: 2020/11/20 15:42:38 [弹幕发送] [发送 11111111111111111111 至 394988]
11111111111111111111
//其他会出现在命令行的信息
//热门榜
I: 2021/02/18 14:59:00 Msg 房 [热门榜 虚拟 4]
//人气
I: 2021/02/18 14:58:51 Reply 人气 [当前人气 450869]
//营收
I: 2021/02/18 14:58:24 功能 [营收 ¥247.80]
//语音
I: 2021/02/18 14:59:00 TTS [0superchat SC: 三得笠·阿克曼茶 8888888 天才oto天才 ]
ctrl+c退出,会同时追加记录到文件danmu.log中(文件记录完整信息,不会减少附加功能作用的弹幕)
danmu.log
基本同命令行显示,不同下列:
//弹幕 上述合并、忽略都不会起作用
I: 2021/02/18 07:24:55 Msg [从天上掉下来的骚年 : 秀才]
//礼物 超过设定限额的将会在命令行中显示,级别为I
T: 2021/02/18 07:30:30 Msg 礼 [正道的光博航同志 投喂 1 个 上上签 ¥1.0]
I: 2021/02/18 14:52:31 Msg 礼 [三千千千千千千 投喂 1 个 爱之魔力 ¥28.0]
//sc
I: 2021/02/18 14:40:54 Msg 礼 [SC: 加拉入我心 ¥ 30 关注了乙女音,我才能够得到快乐 乙女音符に注目してこそ、私は幸せになれるのです。]
I: 2021/02/18 21:48:49 Msg 房 [欢迎舰长 Mana_单推... 进入直播间]
结束后的文件播放效果(显于左上)
Gtk弹幕窗(Linux Only)
更多内容详见注释,如有疑问请发issues,欢迎pr