分享

通过python实现网页录音的效果

 xvdo 2021-11-12

服务器:tornado

语言:python,JS,html

效果:(将录好的音放在指定位置)

实现逻辑:

部分实现代码:

web:

  1. <button type='submit' class='btn btn-primary mb-2 record_start'>开始录音</button>
  2. <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)

  1. $('.record_start').on('click',function(e){
  2. //css中有CHAT的,点击时开始相应,其中' . '代表是在css中,' # '代表是在id中
  3. e.preventDefault();
  4. //防止跳转
  5. args = {'query':'start'}
  6. $.ajax({
  7. async: false,
  8. url:'/record',
  9. type:'POST',
  10. data:$.param(args),
  11. success: function(res){
  12. var data =JSON.parse(res)
  13. if(data.code == 0){
  14. console.log('发送成功');
  15. }
  16. else{
  17. console.error('发送失败');
  18. }
  19. },
  20. error:function(){
  21. console.error('发送失败');
  22. }
  23. })
  24. //$代表jquery,可发起ajax请求,相当于requests,
  25. })
  26. $('.record_stop').on('click',function(e){
  27. //css中有CHAT的,点击时开始相应,其中' . '代表是在css中,' # '代表是在id中
  28. e.preventDefault();
  29. //防止跳转
  30. args = {'query':'stop'}
  31. $.ajax({
  32. async: false,
  33. url:'/record',
  34. type:'POST',
  35. data:$.param(args),
  36. success: function(res){
  37. var data =JSON.parse(res)
  38. if(data.code == 0){
  39. console.log('发送成功');
  40. }
  41. else{
  42. console.error('发送失败');
  43. }
  44. },
  45. error:function(){
  46. console.error('发送失败');
  47. }
  48. })
  49. //$代表jquery,可发起ajax请求,相当于requests,
  50. })

Python server:

  1. static = Record_wav.Final_record()
  2. class RecordHandler(BaseHandler):
  3. global static
  4. def post(self):
  5. query = self.get_argument('query','')
  6. static.record_wav(query)
  7. res = {'code':0,'message':'sucess'}
  8. self.write(json.dumps(res))
  9. self.finish()
  10. def make_app():
  11. return tornado.web.Application([
  12. #其他没用的我删了
  13. (r'/record',RecordHandler)
  14. ],**settings)
  15. '''
  16. **settings:将字典中的元素解析出来,写配置的
  17. '''

这里值得注意的是:定义一个全局变量,因为第二次选择关闭录音的时候也得调用这个类,倘若不加全局,对于static,计算机会重新开辟新空间而不是用之前的,这就导致你的录音没法停止,因为它会停止一个空的录音。

Python Record_wav.py

  1. rec =Recorder()
  2. class Final_record():
  3. def record_wav(self,static):
  4. global rec
  5. if static == 'start':
  6. rec.start()
  7. return 'success!'
  8. elif static=='stop':
  9. rec.stop()
  10. rec.save(fname)
  11. asr=ASR.XunFeiASR()
  12. query=''
  13. query=asr.transcribe(fname)
  14. return query

同上,这儿的对象也得是全局变量。(这俩全局变量想了很久才想出来的,当然,贸然设全局变量很不好,但我只能想到这么多了)

其他的代码,例如录音方面的网上很好找,暂且不再次赘述了。

录音代码可以参考这位博主的:https://blog.csdn.net/qq_29934825/article/details/82982737

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多