python实现网页录音效果
作者:WYH_1998 发布时间:2022-03-19 08:07:15
标签:python,网页录音
本文实例为大家分享了python实现网页录音效果的具体代码,供大家参考,具体内容如下
服务器:tornado
语言:python,JS,html
效果:(将录好的音放在指定位置)
实现逻辑:
部分实现代码:
web:
<button type="submit" class="btn btn-primary mb-2 record_start">开始录音</button>
<button type="submit" class="btn btn-primary mb-2 record_stop">结束录音</button>
注意,class中最后一项 record_start或record_stop,后面JS文件中的方法调用和这个对应
JS:(其中用到Ajax,需要用到jquery-3.4.1.min.js)
$('.record_start').on('click',function(e){
//css中有CHAT的,点击时开始相应,其中' . '代表是在css中,' # '代表是在id中
e.preventDefault();
//防止跳转
args = {'query':'start'}
$.ajax({
async: false,
url:'/record',
type:'POST',
data:$.param(args),
success: function(res){
var data =JSON.parse(res)
if(data.code == 0){
console.log('发送成功');
}
else{
console.error('发送失败');
}
},
error:function(){
console.error('发送失败');
}
})
//$代表jquery,可发起ajax请求,相当于requests,
})
$('.record_stop').on('click',function(e){
//css中有CHAT的,点击时开始相应,其中' . '代表是在css中,' # '代表是在id中
e.preventDefault();
//防止跳转
args = {'query':'stop'}
$.ajax({
async: false,
url:'/record',
type:'POST',
data:$.param(args),
success: function(res){
var data =JSON.parse(res)
if(data.code == 0){
console.log('发送成功');
}
else{
console.error('发送失败');
}
},
error:function(){
console.error('发送失败');
}
})
//$代表jquery,可发起ajax请求,相当于requests,
})
Python server:
static = Record_wav.Final_record()
class RecordHandler(BaseHandler):
global static
def post(self):
query = self.get_argument('query','')
static.record_wav(query)
res = {'code':0,'message':'sucess'}
self.write(json.dumps(res))
self.finish()
def make_app():
return tornado.web.Application([
#其他没用的我删了
(r"/record",RecordHandler)
],**settings)
'''
**settings:将字典中的元素解析出来,写配置的
'''
这里值得注意的是:定义一个全局变量,因为第二次选择关闭录音的时候也得调用这个类,倘若不加全局,对于static,计算机会重新开辟新空间而不是用之前的,这就导致你的录音没法停止,因为它会停止一个空的录音。
Python Record_wav.py
rec =Recorder()
class Final_record():
def record_wav(self,static):
global rec
if static == 'start':
rec.start()
return 'success!'
elif static=='stop':
rec.stop()
rec.save(fname)
asr=ASR.XunFeiASR()
query=''
query=asr.transcribe(fname)
return query
同上,这儿的对象也得是全局变量。(这俩全局变量想了很久才想出来的,当然,贸然设全局变量很不好,但我只能想到这么多了)
其他的代码,例如录音方面的网上很好找,暂且不再次赘述了。
录音代码可以参考这位博主的文章:python实现录音功能(可随时停止录音)
来源:https://blog.csdn.net/qq_37198234/article/details/109267412
0
投稿
猜你喜欢
- 用Python实现批量测试一组url的可用性(可以包括HTTP状态、响应时间等)并统计出现不可用情况的次数和频率等。类似的,这样的脚本可以判
- C#连接数据库:Connection对象1.Connection对象概述Connection对象是一个连接对象,主要功能是建立与物理数据库的
- Python基本输入和输出1.input输入函数input函数:获取用户输入,保存成一个字符串。>>> name = in
- 今天是我们js入门系列演示的最后一节了(暂时我是这样计划的),但是请朋友们记住,前面的实例你都很熟悉了的话也不代表我们就懂了JS,甚至连入门
- 首先,在数据库中创建一个表,用于存放图片:CREATE TABLE Images(Id INT PRIMARY KEY AUTO_INCRE
- 前言有的时候上游传过来的字段是string类型的,但是我们却想用变成数字来使用。 本来用一个json:",string"
- 基于邮件通知的服务监控和告警系统主要功能点:配置专用日志格式记录耗时日志格式:'simple':{'format
- XML.DOM需求有一个表,里面数据量比较大,每天一更新,其字段可以通过xml配置文件进行配置,即,可能每次建表的字段不一样。上游跑时会根据
- MySQL 8.0.19支持输入3次错误密码,锁定账户功能例子:>CREATE USER 'hechunyang'@&
- 这次讨论一下关于select元素的一个问题,其实很早以前我就碰到过关于select元素的问题,这次做网站又被问到同样的问题,就是:一般div
- 首先我们创建数据库表:CREATE TABLE `t_demo` ( `id` int(32) NOT NULL, `name` varch
- 前记在Python中, Dict是一系列由键和值配对组成的元素的集合, 它是一个可变容器模型,可以存储任意类型对象. Dict的存取速度非常
- 一、从 4.0 到 4.1 的主要变化 如果在4.1.0到4.1.3版本的MySQL中创建了包含 TIMESTAMP 字段的 InnoDB表
- ptb数据集是语言模型学习中应用最广泛的数据集,常用该数据集训练RNN神经网络作为语言预测,tensorflow对于ptb数据集的读取也定义
- 引言在 Golang 中,将 URL 打包用于从服务器获取数据非常重要。只需了解您是否正在处理任何应用程序并且您想从任何外部位置或服务器获取
- BLOG阅读:http://www.planabc.net/article.asp?id=118在使用CSS实现表现的时候,会经常接触到di
- 上一文,介绍了vue.js动态添加、删除绑定的radio选项,本文介绍如何选中radio的某一项绑定的数据和上文的model是一致的,选中r
- PHP程序员应该都知道连接MySQL数据库可以使用mysql_pconnect(永久连接)函数,使用数据库永久连接可以提高效率,但是实际应用
- 起源:.clearfix:after {visibility: hidden;display: block;font-size: 0;con
- 本来想等到IE8正式发布时再在blog中写段代码,用来提示IE6用户升级到IE8的,不过貌似IE 8已经RTM了,今天又正好看到这个“升级I