master
parent
87c323da9c
commit
5db191d534
After Width: | Height: | Size: 33 KiB |
After Width: | Height: | Size: 2.4 KiB |
@ -0,0 +1,242 @@
|
||||
2024年 07月 01日 星期一 21:13:13 CST: wenzhi.py 被停止, PID: 29387
|
||||
2024年 07月 01日 星期一 21:13:13 CST: tts.py 运行失败,退出状态码 1, PID: 29405
|
||||
2024年 07月 01日 星期一 21:13:18 CST: wenzhi.py 被停止, PID: 29408
|
||||
2024年 07月 01日 星期一 21:13:18 CST: tts.py 运行失败,退出状态码 1, PID: 29435
|
||||
2024年 07月 01日 星期一 21:13:23 CST: wenzhi.py 被停止, PID: 29456
|
||||
2024年 07月 01日 星期一 21:13:23 CST: tts.py 运行失败,退出状态码 1, PID: 29474
|
||||
2024年 07月 01日 星期一 21:14:26 CST: wenzhi.py 被停止, PID: 29817
|
||||
2024年 07月 01日 星期一 21:14:26 CST: tts.py 运行失败,退出状态码 1, PID: 29835
|
||||
2024年 07月 01日 星期一 21:14:31 CST: wenzhi.py 被停止, PID: 29838
|
||||
2024年 07月 01日 星期一 21:14:31 CST: tts.py 运行失败,退出状态码 1, PID: 29865
|
||||
2024年 07月 01日 星期一 21:16:08 CST: wenzhi.py 被停止, PID: 30373
|
||||
2024年 07月 01日 星期一 21:16:08 CST: tts.py 运行失败,退出状态码 1, PID: 30391
|
||||
2024年 07月 01日 星期一 21:16:13 CST: wenzhi.py 被停止, PID: 30412
|
||||
2024年 07月 01日 星期一 21:16:13 CST: tts.py 运行失败,退出状态码 1, PID: 30466
|
||||
2024年 07月 01日 星期一 21:16:18 CST: wenzhi.py 被停止, PID: 30469
|
||||
2024年 07月 01日 星期一 21:16:18 CST: tts.py 运行失败,退出状态码 1, PID: 30550
|
||||
2024年 07月 01日 星期一 21:16:42 CST: wenzhi.py 被停止, PID: 30664
|
||||
2024年 07月 01日 星期一 21:16:42 CST: tts.py 运行失败,退出状态码 1, PID: 30691
|
||||
2024年 07月 01日 星期一 21:16:47 CST: wenzhi.py 被停止, PID: 30694
|
||||
2024年 07月 01日 星期一 21:16:47 CST: tts.py 运行失败,退出状态码 1, PID: 30721
|
||||
2024年 07月 01日 星期一 21:16:52 CST: wenzhi.py 被停止, PID: 30733
|
||||
2024年 07月 01日 星期一 21:16:52 CST: tts.py 运行失败,退出状态码 1, PID: 30769
|
||||
2024年 07月 01日 星期一 21:16:57 CST: wenzhi.py 被停止, PID: 30781
|
||||
2024年 07月 01日 星期一 21:16:57 CST: tts.py 运行失败,退出状态码 1, PID: 30835
|
||||
2024年 07月 01日 星期一 21:17:02 CST: wenzhi.py 被停止, PID: 30838
|
||||
2024年 07月 01日 星期一 21:17:02 CST: tts.py 运行失败,退出状态码 1, PID: 30895
|
||||
2024年 07月 01日 星期一 21:19:05 CST: wenzhi.py 被停止, PID: 31525
|
||||
2024年 07月 01日 星期一 21:19:05 CST: tts.py 运行失败,退出状态码 1, PID: 31543
|
||||
2024年 07月 01日 星期一 21:19:10 CST: wenzhi.py 被停止, PID: 31546
|
||||
2024年 07月 01日 星期一 21:19:10 CST: tts.py 运行失败,退出状态码 1, PID: 31573
|
||||
2024年 07月 01日 星期一 21:20:16 CST: wenzhi.py 被停止, PID: 31924
|
||||
2024年 07月 01日 星期一 21:20:17 CST: tts.py 运行失败,退出状态码 1, PID: 31960
|
||||
2024年 07月 01日 星期一 21:20:22 CST: wenzhi.py 被停止, PID: 31981
|
||||
2024年 07月 01日 星期一 21:20:22 CST: tts.py 运行失败,退出状态码 1, PID: 32008
|
||||
2024年 07月 01日 星期一 21:20:27 CST: wenzhi.py 被停止, PID: 32029
|
||||
2024年 07月 01日 星期一 21:20:27 CST: tts.py 运行失败,退出状态码 1, PID: 32056
|
||||
2024年 07月 01日 星期一 21:20:32 CST: wenzhi.py 被停止, PID: 32059
|
||||
2024年 07月 01日 星期一 21:20:32 CST: tts.py 运行失败,退出状态码 1, PID: 32086
|
||||
2024年 07月 01日 星期一 21:20:37 CST: wenzhi.py 被停止, PID: 32125
|
||||
2024年 07月 01日 星期一 21:20:37 CST: tts.py 运行失败,退出状态码 1, PID: 32161
|
||||
2024年 07月 01日 星期一 21:20:42 CST: wenzhi.py 被停止, PID: 32191
|
||||
2024年 07月 01日 星期一 21:20:42 CST: tts.py 运行失败,退出状态码 1, PID: 32264
|
||||
2024年 07月 01日 星期一 21:20:47 CST: wenzhi.py 被停止, PID: 32267
|
||||
2024年 07月 01日 星期一 21:20:47 CST: tts.py 运行失败,退出状态码 1, PID: 32303
|
||||
2024年 07月 01日 星期一 21:20:52 CST: wenzhi.py 被停止, PID: 32306
|
||||
2024年 07月 01日 星期一 21:20:52 CST: tts.py 运行失败,退出状态码 1, PID: 32351
|
||||
2024年 07月 01日 星期一 21:20:57 CST: wenzhi.py 被停止, PID: 32354
|
||||
2024年 07月 01日 星期一 21:20:57 CST: tts.py 运行失败,退出状态码 1, PID: 32426
|
||||
2024年 07月 01日 星期一 23:05:26 CST: wenzhi.py 被停止, PID: 8301
|
||||
2024年 07月 01日 星期一 23:05:26 CST: tts.py 运行失败,退出状态码 1, PID: 8318
|
||||
2024年 07月 01日 星期一 23:05:28 CST: wenzhi.py 被停止, PID: 8322
|
||||
2024年 07月 01日 星期一 23:05:28 CST: tts.py 运行失败,退出状态码 1, PID: 8339
|
||||
2024年 07月 01日 星期一 23:05:30 CST: wenzhi.py 被停止, PID: 8352
|
||||
2024年 07月 01日 星期一 23:05:30 CST: tts.py 运行失败,退出状态码 1, PID: 8369
|
||||
2024年 07月 01日 星期一 23:05:32 CST: wenzhi.py 被停止, PID: 8373
|
||||
2024年 07月 01日 星期一 23:05:32 CST: tts.py 运行失败,退出状态码 1, PID: 8400
|
||||
2024年 07月 01日 星期一 23:05:34 CST: wenzhi.py 被停止, PID: 8422
|
||||
2024年 07月 01日 星期一 23:05:34 CST: tts.py 运行失败,退出状态码 1, PID: 8448
|
||||
2024年 07月 01日 星期一 23:09:24 CST: wenzhi.py 被停止, PID: 10042
|
||||
2024年 07月 01日 星期一 23:09:24 CST: tts.py 运行失败,退出状态码 1, PID: 10069
|
||||
2024年 07月 01日 星期一 23:09:26 CST: wenzhi.py 被停止, PID: 10073
|
||||
2024年 07月 01日 星期一 23:09:27 CST: tts.py 运行失败,退出状态码 1, PID: 10090
|
||||
2024年 07月 01日 星期一 23:09:29 CST: wenzhi.py 被停止, PID: 10121
|
||||
2024年 07月 01日 星期一 23:09:29 CST: tts.py 运行失败,退出状态码 1, PID: 10129
|
||||
2024年 07月 01日 星期一 23:09:31 CST: wenzhi.py 被停止, PID: 10178
|
||||
2024年 07月 01日 星期一 23:09:31 CST: tts.py 运行失败,退出状态码 1, PID: 10195
|
||||
2024年 07月 01日 星期一 23:09:33 CST: wenzhi.py 被停止, PID: 10208
|
||||
2024年 07月 01日 星期一 23:09:33 CST: tts.py 运行失败,退出状态码 1, PID: 10225
|
||||
2024年 07月 01日 星期一 23:09:35 CST: wenzhi.py 被停止, PID: 10229
|
||||
2024年 07月 01日 星期一 23:09:35 CST: tts.py 运行失败,退出状态码 1, PID: 10237
|
||||
2024年 07月 01日 星期一 23:09:37 CST: wenzhi.py 被停止, PID: 10241
|
||||
2024年 07月 01日 星期一 23:09:37 CST: tts.py 运行失败,退出状态码 1, PID: 10249
|
||||
2024年 07月 01日 星期一 23:09:39 CST: wenzhi.py 被停止, PID: 10289
|
||||
2024年 07月 01日 星期一 23:09:39 CST: tts.py 运行失败,退出状态码 1, PID: 10306
|
||||
2024年 07月 01日 星期一 23:09:41 CST: wenzhi.py 被停止, PID: 10310
|
||||
2024年 07月 01日 星期一 23:09:41 CST: tts.py 运行失败,退出状态码 1, PID: 10327
|
||||
2024年 07月 01日 星期一 23:09:43 CST: wenzhi.py 被停止, PID: 10340
|
||||
2024年 07月 01日 星期一 23:09:43 CST: tts.py 运行失败,退出状态码 1, PID: 10357
|
||||
2024年 07月 01日 星期一 23:09:45 CST: wenzhi.py 被停止, PID: 10379
|
||||
2024年 07月 01日 星期一 23:09:45 CST: tts.py 运行失败,退出状态码 1, PID: 10396
|
||||
2024年 07月 01日 星期一 23:13:21 CST: wenzhi.py 被停止, PID: 11686
|
||||
2024年 07月 01日 星期一 23:13:21 CST: tts.py 运行成功, PID: 11694
|
||||
2024年 07月 01日 星期一 23:13:23 CST: wenzhi.py 被停止, PID: 11698
|
||||
2024年 07月 01日 星期一 23:13:23 CST: tts.py 运行成功, PID: 11733
|
||||
2024年 07月 01日 星期一 23:14:23 CST: wenzhi.py 被停止, PID: 12133
|
||||
2024年 07月 01日 星期一 23:14:23 CST: tts.py 运行成功, PID: 12141
|
||||
2024年 07月 01日 星期一 23:14:25 CST: wenzhi.py 被停止, PID: 12154
|
||||
2024年 07月 01日 星期一 23:14:25 CST: tts.py 运行成功, PID: 12180
|
||||
2024年 07月 01日 星期一 23:16:13 CST: wenzhi.py 被停止, PID: 12910
|
||||
2024年 07月 01日 星期一 23:16:13 CST: tts.py 运行成功, PID: 12918
|
||||
2024年 07月 01日 星期一 23:16:15 CST: wenzhi.py 被停止, PID: 12940
|
||||
2024年 07月 01日 星期一 23:16:15 CST: tts.py 运行成功, PID: 12957
|
||||
2024年 07月 01日 星期一 23:16:17 CST: wenzhi.py 被停止, PID: 12961
|
||||
2024年 07月 01日 星期一 23:16:17 CST: tts.py 运行成功, PID: 12978
|
||||
2024年 07月 01日 星期一 23:16:19 CST: wenzhi.py 被停止, PID: 12982
|
||||
2024年 07月 01日 星期一 23:16:19 CST: tts.py 运行成功, PID: 12990
|
||||
2024年 07月 01日 星期一 23:16:21 CST: wenzhi.py 被停止, PID: 12994
|
||||
2024年 07月 01日 星期一 23:16:21 CST: tts.py 运行成功, PID: 13002
|
||||
2024年 07月 01日 星期一 23:16:23 CST: wenzhi.py 被停止, PID: 13024
|
||||
2024年 07月 01日 星期一 23:16:23 CST: tts.py 运行成功, PID: 13041
|
||||
2024年 07月 01日 星期一 23:16:25 CST: wenzhi.py 被停止, PID: 13054
|
||||
2024年 07月 01日 星期一 23:16:25 CST: tts.py 运行成功, PID: 13062
|
||||
2024年 07月 01日 星期一 23:16:27 CST: wenzhi.py 被停止, PID: 13075
|
||||
2024年 07月 01日 星期一 23:16:27 CST: tts.py 运行成功, PID: 13083
|
||||
2024年 07月 01日 星期一 23:17:10 CST: wenzhi.py 被停止, PID: 13388
|
||||
2024年 07月 01日 星期一 23:17:10 CST: tts.py 运行成功, PID: 13396
|
||||
2024年 07月 01日 星期一 23:17:12 CST: wenzhi.py 被停止, PID: 13400
|
||||
2024年 07月 01日 星期一 23:17:12 CST: tts.py 运行成功, PID: 13408
|
||||
2024年 07月 01日 星期一 23:17:23 CST: wenzhi.py 被停止, PID: 13502
|
||||
2024年 07月 01日 星期一 23:17:23 CST: tts.py 运行成功, PID: 13510
|
||||
2024年 07月 01日 星期一 23:17:25 CST: wenzhi.py 被停止, PID: 13514
|
||||
2024年 07月 01日 星期一 23:17:25 CST: tts.py 运行成功, PID: 13522
|
||||
2024年 07月 01日 星期一 23:17:27 CST: wenzhi.py 被停止, PID: 13526
|
||||
2024年 07月 01日 星期一 23:17:27 CST: tts.py 运行成功, PID: 13534
|
||||
2024年 07月 01日 星期一 23:17:59 CST: wenzhi.py 被停止, PID: 13762
|
||||
2024年 07月 01日 星期一 23:17:59 CST: tts.py 运行失败,退出状态码 1, PID: 13779
|
||||
2024年 07月 01日 星期一 23:18:01 CST: wenzhi.py 被停止, PID: 13783
|
||||
2024年 07月 01日 星期一 23:18:01 CST: tts.py 运行失败,退出状态码 1, PID: 13791
|
||||
2024年 07月 01日 星期一 23:18:03 CST: wenzhi.py 被停止, PID: 13795
|
||||
2024年 07月 01日 星期一 23:18:03 CST: tts.py 运行失败,退出状态码 1, PID: 13821
|
||||
2024年 07月 01日 星期一 23:18:05 CST: wenzhi.py 被停止, PID: 13825
|
||||
2024年 07月 01日 星期一 23:18:05 CST: tts.py 运行失败,退出状态码 1, PID: 13833
|
||||
2024年 07月 01日 星期一 23:18:07 CST: wenzhi.py 被停止, PID: 13837
|
||||
2024年 07月 01日 星期一 23:18:07 CST: tts.py 运行失败,退出状态码 1, PID: 13854
|
||||
2024年 07月 01日 星期一 23:18:09 CST: wenzhi.py 被停止, PID: 13867
|
||||
2024年 07月 01日 星期一 23:18:09 CST: tts.py 运行失败,退出状态码 1, PID: 13875
|
||||
2024年 07月 01日 星期一 23:18:11 CST: wenzhi.py 被停止, PID: 13879
|
||||
2024年 07月 01日 星期一 23:18:11 CST: tts.py 运行失败,退出状态码 1, PID: 13887
|
||||
2024年 07月 01日 星期一 23:18:13 CST: wenzhi.py 被停止, PID: 13891
|
||||
2024年 07月 01日 星期一 23:18:13 CST: tts.py 运行失败,退出状态码 1, PID: 13899
|
||||
2024年 07月 01日 星期一 23:18:15 CST: wenzhi.py 被停止, PID: 13903
|
||||
2024年 07月 01日 星期一 23:18:15 CST: tts.py 运行失败,退出状态码 1, PID: 13911
|
||||
2024年 07月 01日 星期一 23:18:17 CST: wenzhi.py 被停止, PID: 13915
|
||||
2024年 07月 01日 星期一 23:18:18 CST: tts.py 运行失败,退出状态码 1, PID: 13923
|
||||
2024年 07月 01日 星期一 23:18:20 CST: wenzhi.py 被停止, PID: 13927
|
||||
2024年 07月 01日 星期一 23:18:20 CST: tts.py 运行失败,退出状态码 1, PID: 13935
|
||||
2024年 07月 01日 星期一 23:18:22 CST: wenzhi.py 被停止, PID: 13939
|
||||
2024年 07月 01日 星期一 23:18:22 CST: tts.py 运行失败,退出状态码 1, PID: 13947
|
||||
2024年 07月 01日 星期一 23:18:24 CST: wenzhi.py 被停止, PID: 13960
|
||||
2024年 07月 01日 星期一 23:18:24 CST: tts.py 运行失败,退出状态码 1, PID: 13968
|
||||
2024年 07月 01日 星期一 23:18:26 CST: wenzhi.py 被停止, PID: 13972
|
||||
2024年 07月 01日 星期一 23:18:26 CST: tts.py 运行失败,退出状态码 1, PID: 13980
|
||||
2024年 07月 01日 星期一 23:18:28 CST: wenzhi.py 被停止, PID: 13984
|
||||
2024年 07月 01日 星期一 23:18:28 CST: tts.py 运行失败,退出状态码 1, PID: 13992
|
||||
2024年 07月 01日 星期一 23:18:30 CST: wenzhi.py 被停止, PID: 13996
|
||||
2024年 07月 01日 星期一 23:18:30 CST: tts.py 运行失败,退出状态码 1, PID: 14004
|
||||
2024年 07月 01日 星期一 23:18:32 CST: wenzhi.py 被停止, PID: 14017
|
||||
2024年 07月 01日 星期一 23:18:32 CST: tts.py 运行失败,退出状态码 1, PID: 14025
|
||||
2024年 07月 01日 星期一 23:18:34 CST: wenzhi.py 被停止, PID: 14029
|
||||
2024年 07月 01日 星期一 23:18:34 CST: tts.py 运行失败,退出状态码 1, PID: 14046
|
||||
2024年 07月 01日 星期一 23:18:36 CST: wenzhi.py 被停止, PID: 14050
|
||||
2024年 07月 01日 星期一 23:18:36 CST: tts.py 运行失败,退出状态码 1, PID: 14076
|
||||
2024年 07月 01日 星期一 23:18:38 CST: wenzhi.py 被停止, PID: 14080
|
||||
2024年 07月 01日 星期一 23:18:38 CST: tts.py 运行失败,退出状态码 1, PID: 14088
|
||||
2024年 07月 01日 星期一 23:18:40 CST: wenzhi.py 被停止, PID: 14092
|
||||
2024年 07月 01日 星期一 23:18:40 CST: tts.py 运行失败,退出状态码 1, PID: 14109
|
||||
2024年 07月 01日 星期一 23:18:42 CST: wenzhi.py 被停止, PID: 14113
|
||||
2024年 07月 01日 星期一 23:18:42 CST: tts.py 运行失败,退出状态码 1, PID: 14130
|
||||
2024年 07月 01日 星期一 23:18:44 CST: wenzhi.py 被停止, PID: 14134
|
||||
2024年 07月 01日 星期一 23:18:44 CST: tts.py 运行失败,退出状态码 1, PID: 14142
|
||||
2024年 07月 01日 星期一 23:18:46 CST: wenzhi.py 被停止, PID: 14146
|
||||
2024年 07月 01日 星期一 23:18:46 CST: tts.py 运行失败,退出状态码 1, PID: 14154
|
||||
2024年 07月 01日 星期一 23:18:48 CST: wenzhi.py 被停止, PID: 14167
|
||||
2024年 07月 01日 星期一 23:18:48 CST: tts.py 运行失败,退出状态码 1, PID: 14184
|
||||
2024年 07月 01日 星期一 23:18:50 CST: wenzhi.py 被停止, PID: 14197
|
||||
2024年 07月 01日 星期一 23:18:50 CST: tts.py 运行失败,退出状态码 1, PID: 14223
|
||||
2024年 07月 01日 星期一 23:18:52 CST: wenzhi.py 被停止, PID: 14227
|
||||
2024年 07月 01日 星期一 23:18:52 CST: tts.py 运行失败,退出状态码 1, PID: 14235
|
||||
2024年 07月 01日 星期一 23:18:54 CST: wenzhi.py 被停止, PID: 14248
|
||||
2024年 07月 01日 星期一 23:18:54 CST: tts.py 运行失败,退出状态码 1, PID: 14282
|
||||
2024年 07月 01日 星期一 23:18:56 CST: wenzhi.py 被停止, PID: 14296
|
||||
2024年 07月 01日 星期一 23:18:56 CST: tts.py 运行失败,退出状态码 1, PID: 14313
|
||||
2024年 07月 01日 星期一 23:18:58 CST: wenzhi.py 被停止, PID: 14334
|
||||
2024年 07月 01日 星期一 23:18:58 CST: tts.py 运行失败,退出状态码 1, PID: 14361
|
||||
2024年 07月 01日 星期一 23:19:00 CST: wenzhi.py 被停止, PID: 14374
|
||||
2024年 07月 01日 星期一 23:19:00 CST: tts.py 运行失败,退出状态码 1, PID: 14391
|
||||
2024年 07月 01日 星期一 23:19:02 CST: wenzhi.py 被停止, PID: 14395
|
||||
2024年 07月 01日 星期一 23:19:02 CST: tts.py 运行失败,退出状态码 1, PID: 14403
|
||||
2024年 07月 01日 星期一 23:19:04 CST: wenzhi.py 被停止, PID: 14425
|
||||
2024年 07月 01日 星期一 23:19:04 CST: tts.py 运行失败,退出状态码 1, PID: 14433
|
||||
2024年 07月 01日 星期一 23:19:06 CST: wenzhi.py 被停止, PID: 14446
|
||||
2024年 07月 01日 星期一 23:19:07 CST: tts.py 运行失败,退出状态码 1, PID: 14463
|
||||
2024年 07月 01日 星期一 23:19:09 CST: wenzhi.py 被停止, PID: 14485
|
||||
2024年 07月 01日 星期一 23:19:09 CST: tts.py 运行失败,退出状态码 1, PID: 14502
|
||||
2024年 07月 01日 星期一 23:19:11 CST: wenzhi.py 被停止, PID: 14515
|
||||
2024年 07月 01日 星期一 23:19:11 CST: tts.py 运行失败,退出状态码 1, PID: 14532
|
||||
2024年 07月 01日 星期一 23:19:13 CST: wenzhi.py 被停止, PID: 14536
|
||||
2024年 07月 01日 星期一 23:19:13 CST: tts.py 运行失败,退出状态码 1, PID: 14544
|
||||
2024年 07月 01日 星期一 23:19:15 CST: wenzhi.py 被停止, PID: 14548
|
||||
2024年 07月 01日 星期一 23:19:15 CST: tts.py 运行失败,退出状态码 1, PID: 14574
|
||||
2024年 07月 01日 星期一 23:19:17 CST: wenzhi.py 被停止, PID: 14578
|
||||
2024年 07月 01日 星期一 23:19:17 CST: tts.py 运行失败,退出状态码 1, PID: 14586
|
||||
2024年 07月 01日 星期一 23:19:19 CST: wenzhi.py 被停止, PID: 14599
|
||||
2024年 07月 01日 星期一 23:19:19 CST: tts.py 运行失败,退出状态码 1, PID: 14616
|
||||
2024年 07月 01日 星期一 23:19:21 CST: wenzhi.py 被停止, PID: 14620
|
||||
2024年 07月 01日 星期一 23:19:21 CST: tts.py 运行失败,退出状态码 1, PID: 14646
|
||||
2024年 07月 01日 星期一 23:19:23 CST: wenzhi.py 被停止, PID: 14650
|
||||
2024年 07月 01日 星期一 23:19:23 CST: tts.py 运行失败,退出状态码 1, PID: 14658
|
||||
2024年 07月 01日 星期一 23:19:25 CST: wenzhi.py 被停止, PID: 14671
|
||||
2024年 07月 01日 星期一 23:19:25 CST: tts.py 运行失败,退出状态码 1, PID: 14679
|
||||
2024年 07月 01日 星期一 23:19:27 CST: wenzhi.py 被停止, PID: 14692
|
||||
2024年 07月 01日 星期一 23:19:27 CST: tts.py 运行失败,退出状态码 1, PID: 14709
|
||||
2024年 07月 01日 星期一 23:19:29 CST: wenzhi.py 被停止, PID: 14713
|
||||
2024年 07月 01日 星期一 23:19:29 CST: tts.py 运行失败,退出状态码 1, PID: 14721
|
||||
2024年 07月 01日 星期一 23:19:31 CST: wenzhi.py 被停止, PID: 14735
|
||||
2024年 07月 01日 星期一 23:19:31 CST: tts.py 运行失败,退出状态码 1, PID: 14743
|
||||
2024年 07月 01日 星期一 23:19:33 CST: wenzhi.py 被停止, PID: 14756
|
||||
2024年 07月 01日 星期一 23:19:33 CST: tts.py 运行失败,退出状态码 1, PID: 14773
|
||||
2024年 07月 01日 星期一 23:19:35 CST: wenzhi.py 被停止, PID: 14777
|
||||
2024年 07月 01日 星期一 23:19:35 CST: tts.py 运行失败,退出状态码 1, PID: 14785
|
||||
2024年 07月 01日 星期一 23:19:37 CST: wenzhi.py 被停止, PID: 14798
|
||||
2024年 07月 01日 星期一 23:19:37 CST: tts.py 运行失败,退出状态码 1, PID: 14815
|
||||
2024年 07月 01日 星期一 23:19:39 CST: wenzhi.py 被停止, PID: 14819
|
||||
2024年 07月 01日 星期一 23:19:39 CST: tts.py 运行失败,退出状态码 1, PID: 14836
|
||||
2024年 07月 01日 星期一 23:19:41 CST: wenzhi.py 被停止, PID: 14840
|
||||
2024年 07月 01日 星期一 23:19:41 CST: tts.py 运行失败,退出状态码 1, PID: 14848
|
||||
2024年 07月 01日 星期一 23:19:43 CST: wenzhi.py 被停止, PID: 14852
|
||||
2024年 07月 01日 星期一 23:19:43 CST: tts.py 运行失败,退出状态码 1, PID: 14860
|
||||
2024年 07月 01日 星期一 23:19:45 CST: wenzhi.py 被停止, PID: 14864
|
||||
2024年 07月 01日 星期一 23:19:45 CST: tts.py 运行失败,退出状态码 1, PID: 14872
|
||||
2024年 07月 01日 星期一 23:19:47 CST: wenzhi.py 被停止, PID: 14885
|
||||
2024年 07月 01日 星期一 23:19:47 CST: tts.py 运行失败,退出状态码 1, PID: 14893
|
||||
2024年 07月 01日 星期一 23:19:49 CST: wenzhi.py 被停止, PID: 14897
|
||||
2024年 07月 01日 星期一 23:19:49 CST: tts.py 运行失败,退出状态码 1, PID: 14905
|
||||
2024年 07月 01日 星期一 23:19:51 CST: wenzhi.py 被停止, PID: 14909
|
||||
2024年 07月 01日 星期一 23:19:51 CST: tts.py 运行失败,退出状态码 1, PID: 14926
|
||||
2024年 07月 01日 星期一 23:19:53 CST: wenzhi.py 被停止, PID: 14948
|
||||
2024年 07月 01日 星期一 23:19:53 CST: tts.py 运行失败,退出状态码 1, PID: 14956
|
||||
2024年 07月 01日 星期一 23:19:55 CST: wenzhi.py 被停止, PID: 14969
|
||||
2024年 07月 01日 星期一 23:19:55 CST: tts.py 运行失败,退出状态码 1, PID: 14977
|
||||
2024年 07月 01日 星期一 23:19:58 CST: wenzhi.py 被停止, PID: 14981
|
||||
2024年 07月 01日 星期一 23:19:58 CST: tts.py 运行失败,退出状态码 1, PID: 15007
|
||||
2024年 07月 01日 星期一 23:20:00 CST: wenzhi.py 被停止, PID: 15020
|
||||
2024年 07月 01日 星期一 23:20:00 CST: tts.py 运行失败,退出状态码 1, PID: 15037
|
||||
2024年 07月 01日 星期一 23:20:02 CST: wenzhi.py 被停止, PID: 15041
|
||||
2024年 07月 01日 星期一 23:20:02 CST: tts.py 运行失败,退出状态码 1, PID: 15049
|
||||
2024年 07月 01日 星期一 23:20:04 CST: wenzhi.py 被停止, PID: 15053
|
||||
2024年 07月 01日 星期一 23:20:04 CST: tts.py 运行失败,退出状态码 1, PID: 15061
|
||||
2024年 07月 01日 星期一 23:20:06 CST: wenzhi.py 被停止, PID: 15067
|
||||
2024年 07月 01日 星期一 23:20:06 CST: tts.py 运行失败,退出状态码 1, PID: 15075
|
||||
2024年 07月 01日 星期一 23:20:08 CST: wenzhi.py 被停止, PID: 15079
|
||||
2024年 07月 01日 星期一 23:20:08 CST: tts.py 运行失败,退出状态码 1, PID: 15105
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -0,0 +1,194 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
import collections
|
||||
import pyaudio
|
||||
import snowboydetect
|
||||
import time
|
||||
import wave
|
||||
import os
|
||||
import logging
|
||||
|
||||
logging.basicConfig()
|
||||
logger = logging.getLogger("snowboy")
|
||||
logger.setLevel(logging.INFO)
|
||||
TOP_DIR = os.path.dirname(os.path.abspath(__file__))
|
||||
|
||||
RESOURCE_FILE = os.path.join(TOP_DIR, "resources/common.res")
|
||||
DETECT_DING = os.path.join(TOP_DIR, "resources/ding.wav")
|
||||
DETECT_DONG = os.path.join(TOP_DIR, "resources/dong.wav")
|
||||
|
||||
|
||||
class RingBuffer(object):
|
||||
"""Ring buffer to hold audio from PortAudio"""
|
||||
|
||||
def __init__(self, size=4096):
|
||||
self._buf = collections.deque(maxlen=size)
|
||||
|
||||
def extend(self, data):
|
||||
"""Adds data to the end of buffer"""
|
||||
self._buf.extend(data)
|
||||
|
||||
def get(self):
|
||||
"""Retrieves data from the beginning of buffer and clears it"""
|
||||
tmp = bytes(bytearray(self._buf))
|
||||
self._buf.clear()
|
||||
return tmp
|
||||
|
||||
|
||||
def play_audio_file(fname=DETECT_DING):
|
||||
"""Simple callback function to play a wave file. By default it plays
|
||||
a Ding sound.
|
||||
|
||||
:param str fname: wave file name
|
||||
:return: None
|
||||
"""
|
||||
# 打开wave文件
|
||||
ding_wav = wave.open(fname, 'rb')
|
||||
# 读取文件内容
|
||||
ding_data = ding_wav.readframes(ding_wav.getnframes())
|
||||
# 初始化pyaudio
|
||||
audio = pyaudio.PyAudio()
|
||||
# 打开音频流
|
||||
stream_out = audio.open(
|
||||
format=audio.get_format_from_width(ding_wav.getsampwidth()),
|
||||
channels=ding_wav.getnchannels(),
|
||||
rate=ding_wav.getframerate(), input=False, output=True)
|
||||
# 开始音频流
|
||||
stream_out.start_stream()
|
||||
# 写入音频数据
|
||||
stream_out.write(ding_data)
|
||||
# 等待0.2秒
|
||||
time.sleep(0.2)
|
||||
# 停止音频流
|
||||
stream_out.stop_stream()
|
||||
stream_out.close()
|
||||
# 关闭pyaudio
|
||||
audio.terminate()
|
||||
|
||||
|
||||
class HotwordDetector(object):
|
||||
"""
|
||||
Snowboy decoder to detect whether a keyword specified by `decoder_model`
|
||||
exists in a microphone input stream.
|
||||
|
||||
:param decoder_model: decoder model file path, a string or a list of strings
|
||||
:param resource: resource file path.
|
||||
:param sensitivity: decoder sensitivity, a float of a list of floats.
|
||||
The bigger the value, the more senstive the
|
||||
decoder. If an empty list is provided, then the
|
||||
default sensitivity in the model will be used.
|
||||
:param audio_gain: multiply input volume by this factor.
|
||||
"""
|
||||
|
||||
def __init__(self, decoder_model,
|
||||
resource=RESOURCE_FILE,
|
||||
sensitivity=[],
|
||||
audio_gain=1):
|
||||
|
||||
def audio_callback(in_data, frame_count, time_info, status):
|
||||
self.ring_buffer.extend(in_data)
|
||||
play_data = chr(0) * len(in_data)
|
||||
return play_data, pyaudio.paContinue
|
||||
|
||||
tm = type(decoder_model)
|
||||
ts = type(sensitivity)
|
||||
if tm is not list:
|
||||
decoder_model = [decoder_model]
|
||||
if ts is not list:
|
||||
sensitivity = [sensitivity]
|
||||
model_str = ",".join(decoder_model)
|
||||
|
||||
self.detector = snowboydetect.SnowboyDetect(
|
||||
resource_filename=resource.encode(), model_str=model_str.encode())
|
||||
self.detector.SetAudioGain(audio_gain)
|
||||
self.num_hotwords = self.detector.NumHotwords()
|
||||
|
||||
if len(decoder_model) > 1 and len(sensitivity) == 1:
|
||||
sensitivity = sensitivity*self.num_hotwords
|
||||
if len(sensitivity) != 0:
|
||||
assert self.num_hotwords == len(sensitivity), \
|
||||
"number of hotwords in decoder_model (%d) and sensitivity " \
|
||||
"(%d) does not match" % (self.num_hotwords, len(sensitivity))
|
||||
sensitivity_str = ",".join([str(t) for t in sensitivity])
|
||||
if len(sensitivity) != 0:
|
||||
self.detector.SetSensitivity(sensitivity_str.encode())
|
||||
|
||||
self.ring_buffer = RingBuffer(
|
||||
self.detector.NumChannels() * self.detector.SampleRate() * 5)
|
||||
self.audio = pyaudio.PyAudio()
|
||||
self.stream_in = self.audio.open(
|
||||
input=True, output=False,
|
||||
format=self.audio.get_format_from_width(
|
||||
self.detector.BitsPerSample() / 8),
|
||||
channels=self.detector.NumChannels(),
|
||||
rate=self.detector.SampleRate(),
|
||||
frames_per_buffer=2048,
|
||||
stream_callback=audio_callback)
|
||||
|
||||
def start(self, detected_callback=play_audio_file,
|
||||
interrupt_check=lambda: False,
|
||||
sleep_time=0.03):
|
||||
"""
|
||||
Start the voice detector. For every `sleep_time` second it checks the
|
||||
audio buffer for triggering keywords. If detected, then call
|
||||
corresponding function in `detected_callback`, which can be a single
|
||||
function (single model) or a list of callback functions (multiple
|
||||
models). Every loop it also calls `interrupt_check` -- if it returns
|
||||
True, then breaks from the loop and return.
|
||||
|
||||
:param detected_callback: a function or list of functions. The number of
|
||||
items must match the number of models in
|
||||
`decoder_model`.
|
||||
:param interrupt_check: a function that returns True if the main loop
|
||||
needs to stop.
|
||||
:param float sleep_time: how much time in second every loop waits.
|
||||
:return: None
|
||||
"""
|
||||
if interrupt_check():
|
||||
logger.debug("detect voice return")
|
||||
return
|
||||
|
||||
tc = type(detected_callback)
|
||||
if tc is not list:
|
||||
detected_callback = [detected_callback]
|
||||
if len(detected_callback) == 1 and self.num_hotwords > 1:
|
||||
detected_callback *= self.num_hotwords
|
||||
|
||||
assert self.num_hotwords == len(detected_callback), \
|
||||
"Error: hotwords in your models (%d) do not match the number of " \
|
||||
"callbacks (%d)" % (self.num_hotwords, len(detected_callback))
|
||||
|
||||
logger.debug("detecting...")
|
||||
|
||||
while True:
|
||||
if interrupt_check():
|
||||
logger.debug("detect voice break")
|
||||
break
|
||||
data = self.ring_buffer.get()
|
||||
if len(data) == 0:
|
||||
time.sleep(sleep_time)
|
||||
continue
|
||||
|
||||
ans = self.detector.RunDetection(data)
|
||||
if ans == -1:
|
||||
logger.warning(
|
||||
"Error initializing streams or reading audio data")
|
||||
elif ans > 0:
|
||||
message = "Keyword " + str(ans) + " detected at time: "
|
||||
message += time.strftime("%Y-%m-%d %H:%M:%S",
|
||||
time.localtime(time.time()))
|
||||
logger.info(message)
|
||||
callback = detected_callback[ans-1]
|
||||
if callback is not None:
|
||||
callback()
|
||||
|
||||
logger.debug("finished.")
|
||||
|
||||
def terminate(self):
|
||||
"""
|
||||
Terminate audio stream. Users cannot call start() again to detect.
|
||||
:return: None
|
||||
"""
|
||||
self.stream_in.stop_stream()
|
||||
self.stream_in.close()
|
||||
self.audio.terminate()
|
@ -0,0 +1,52 @@
|
||||
import unittest
|
||||
from unittest.mock import MagicMock
|
||||
from unittest.mock import patch
|
||||
|
||||
class TestMyCode(unittest.TestCase):
|
||||
|
||||
def setUp(self):
|
||||
self.detector = MagicMock(spec=snowboydecoder.HotwordDetector)
|
||||
self.pa = MagicMock(spec=PyAudio)
|
||||
self.wf = MagicMock(spec=wave.open)
|
||||
self.p = MagicMock()
|
||||
self.stream = MagicMock()
|
||||
self.data = MagicMock()
|
||||
|
||||
@patch('snowboydecoder.HotwordDetector')
|
||||
@patch('PyAudio.PyAudio')
|
||||
@patch('wave.open')
|
||||
def test_detected(self, mock_wave_open, mock_pyaudio, mock_hotword_detector):
|
||||
mock_hotword_detector.return_value = self.detector
|
||||
self.detector.start = MagicMock()
|
||||
self.detector.terminate = MagicMock()
|
||||
|
||||
with patch('builtins.print') as mock_print:
|
||||
detected()
|
||||
mock_print.assert_called_with('唤醒成功')
|
||||
self.detector.start.assert_called_with(detected_callback=detected, interrupt_check=interrupt_callback, sleep_time=0.03)
|
||||
self.detector.terminate.assert_called()
|
||||
|
||||
@patch('PyAudio.PyAudio')
|
||||
@patch('wave.open')
|
||||
def test_my_record(self, mock_wave_open, mock_pyaudio):
|
||||
self.pa.return_value = self.pa
|
||||
self.pa.open = MagicMock(return_value=self.stream)
|
||||
self.stream.read = MagicMock(return_value=self.data)
|
||||
|
||||
my_record()
|
||||
|
||||
self.pa.open.assert_called_with(format=paInt16, channels=channels, rate=framerate, input=True, frames_per_buffer=num_samples)
|
||||
self.stream.read.assert_called_with(num_samples)
|
||||
|
||||
@patch('requests.post')
|
||||
def test_speech2text(self, mock_requests_post):
|
||||
mock_response = MagicMock()
|
||||
mock_response.json = MagicMock(return_value={'result': ['你好']})
|
||||
mock_requests_post.return_value = mock_response
|
||||
|
||||
speech = MagicMock()
|
||||
result = speech2text(speech, 'token')
|
||||
self.assertEqual(result, '你好')
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main()
|
Binary file not shown.
Loading…
Reference in new issue