#Python 同声传译工具 开发中

功能概述
允许用户选择通过麦克风(microphone)或者获取系统声音(system_sound)作为语音输入源。
对输入的语音进行识别,得到对应的文本内容。
将识别出的文本翻译成指定的目标语言。
把翻译后的文本转换为语音并播放出来。

import speech_recognition as sr
from gtts import gTTS
from googletrans import Translator
import os
import time
import pyaudio
import pyshark# 创建识别器对象
r = sr.Recognizer()
# 创建翻译器对象
translator = Translator()def recognize_speech(language, input_type="microphone"):if input_type == "microphone":with sr.Microphone() as source:print(f"请说话({language}):")audio = r.listen(source)elif input_type == "system_sound":CHUNK = 1024FORMAT = pyaudio.paInt16CHANNELS = 1RATE = 44100p = pyaudio.PyAudio()stream = p.open(format=FORMAT,channels=CHANNELS,rate=RATE,input=True,frames_per_buffer=CHUNK)print(f"正在获取系统声音({language}),请在系统中播放相关音频...")frames = []for i in range(0, int(RATE / CHUNK * 5)):  # 获取5秒钟的音频数据,可根据需要调整data = stream.read(CHUNK)frames.append(data)stream.stop_stream()stream.close()p.terminate()audio_data = sr.AudioData(b''.join(frames), RATE, FORMAT)else:raise ValueError("无效的输入类型,可选'microphone'或'system_sound'")try:if input_type == "microphone":text = r.recognize_google(audio, language=language)elif input_type == "system_sound":text = r.recognize_google(audio_data, language=language)print(f"识别结果: {text}")return textexcept sr.UnknownError:print("无法识别语音")except sr.RequestError as e:print(f"请求错误:{e}")def translate_text(text, target_language):translation = translator.translate(text, dest=target_language)print(f"翻译结果: {translation.text}")return translation.textdef speak_text(text, language):tts = gTTS(text=text, lang=language)tts.save("output.mp3")os.system("mpg123 output.mp3")os.remove("output.mp3")if __name__ == "__main__":source_language = "en-US"  # 源语言,这里设置为英语(美国),可根据需要修改target_language = "zh-CN"  # 目标语言,这里设置为中文(中国大陆),可根据需要修改input_option = input("请选择输入方式(microphone/system_sound):")while True:recognized_text = recognize_speech(source_language, input_type=input_option)if recognized_text:translated_text = translate_text(recognized_text, target_language)speak_text(translated_text, target_language)time.sleep(2)  # 暂停2秒,避免过于频繁的识别

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/62658.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

多线程篇-8--线程安全(死锁,常用保障安全的方法,安全容器,原子类,Fork/Join框架等)

1、线程安全和不安全定义 (1)、线程安全 线程安全是指一个类或方法在被多个线程访问的情况下可以正确得到结果,不会出现数据不一致或其他错误行为。 线程安全的条件 1、原子性(Atomicity) 多个操作要么全部完成&a…

API 与 SDK 之间的区别

API 与 SDK 之间的区别 很多人在软件开发中经常会分不清 SDK 与 API ,今天就来浅谈一下两者之间的区别。 直白地说,SDK 包含了 API ,是一套完整的,能完成更多功能的工具包,无论你想获取什么样的信息,SDK …

自动驾驶决策规划算法-路径决策算法:二次规划

本文为学习自动驾驶决策规划算法第二章第四节(中) 路径二次规划算法》的学习笔记。 1 二次型 二次型的形式为 1 2 x T H x f T x \begin{equation} \frac{1}{2}\boldsymbol{x}^TH\boldsymbol{x}f^T\boldsymbol{x} \end{equation} 21​xTHxfTx​​ 约束 A e q x b e q \be…

AI开发-数据可视化库-Seaborn

1 需求 概述 Seaborn 是一个基于 Python 的数据可视化库,它建立在 Matplotlib 之上。其主要目的是使数据可视化更加美观、方便和高效。它提供了高层次的接口和各种美观的默认主题,能够帮助用户快速创建出具有吸引力的统计图表,用于数据分析和…

详细介绍Node.js的中间件及使用方法

在Node.js的生态中,中间件(Middleware)是一个不可或缺的概念,它为构建灵活而高效的应用程序提供了强大的支持。以下是对Node.js中间件的详细介绍: 中间件的概念与定义 中间件是一种软件架构的设计模式,用…

指针与字符串简单练习

【问题描述】使用字符型指针数组,存储周一到周日的英文(首字母大写)。输入数字1-7任意一个数字,输出英文Monday-Sunday的对应英文。 【输入形式】 数字1-7的任一数字。 【输出形式】 英文Monday-Sunday的对应英文。 【样例输入…

相交链表和环形链表

(一)相交链表 相交链表 思路:先分别计算出A列表和B列表的长度,判断它们的尾节点是否相等,如果不相等就不相交,直接返回空。然后让两个列表中的长的列表先走它们的差距步,然后再一起走&#xff…

【学术投稿】Imagen:重塑图像生成领域的革命性突破

【连续七届已快稳ei检索】第八届电子信息技术与计算机工程国际学术会议(EITCE 2024)_艾思科蓝_学术一站式服务平台 更多学术会议请看 https://ais.cn/u/nuyAF3 目录 引言 一、Imagen模型的技术原理 1. 模型概述 2. 工作流程 3. 技术创新 二、Ima…

简单搭建qiankun的主应用和子应用并且用Docker进行服务器部署

在node18环境下,用react18创建qiankun主应用和两个子应用,react路由用V6版本,都在/main路由下访问子应用,用Dockerfile部署到腾讯云CentOS7.6服务器的8000端口进行访问,且在部署过程中进行nginx配置以进行合理的路由访…

封闭解(Closed-Form Solution)与复杂数值优化(Complex Numerical Optimization)的比较:中英双语

中文版 什么是封闭解? 在数学和统计学中,封闭解(Closed-Form Solution) 是指通过有限次基本运算(如加减乘除、开方、对数、指数运算等)即可明确表达的解。这意味着,当我们遇到一个数学问题或模…

[Redis#12] 常用类型接口学习 | string | list

目录 0.准备 1.string get | set set_with_timeout_test.cpp set_nx_xx_test.cpp mset_test.cpp mget_test.cpp getrange_setrange_test.cpp incr_decr_test.cpp 2.list lpush_lrange_test.cpp rpush_test.cpp lpop_rpop_test.cpp blpop_test.cpp llen_test.cpp…

A054-基于Spring Boot的青年公寓服务平台的设计与实现

🙊作者简介:在校研究生,拥有计算机专业的研究生开发团队,分享技术代码帮助学生学习,独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取,记得注明来意哦~🌹 赠送计算机毕业设计600…

【经典】星空主题的注册界面HTML,CSS,JS

目录 界面展示 完整代码 说明&#xff1a; 这是一个简单的星空主题的注册界面&#xff0c;使用了 HTML 和 CSS 来实现一个背景为星空效果的注册页面。 界面展示 完整代码 <!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8&…

TiDB 优化器丨执行计划和 SQL 算子解读最佳实践

作者&#xff1a; TiDB社区小助手 原文来源&#xff1a; https://tidb.net/blog/5edb7933 导读 在数据库系统中&#xff0c;查询优化器是数据库管理系统的核心组成部分&#xff0c;负责将用户的 SQL 查询转化为高效的执行计划&#xff0c;因而会直接影响用户体感的性能与稳…

C_接口函数

接口函数在编程中是一种常见的设计模式&#xff0c;广泛应用于实现模块化、解耦合、提高代码可复用性等方面。在 C 语言中&#xff0c;接口函数通常通过函数指针传递函数作为参数&#xff0c;从而允许动态选择执行的功能或算法。接口函数的使用场景很多&#xff0c;下面我会列举…

python 操作二进制文件(视频、音频、文本)

一、读写方法 file open(文件,模式) #不需要指定编码格式moderb #读取二进制文件modewb #写入二进制文件 二、案例 读取 #以rb模式打开二进制图片 xiaoming.jpg imgopen(小明.jpg,moderb) #读取文件内容 content img.read() print(content) #关闭打开的文件 img.close()…

位运算在嵌入式系统开发中的应用

目录 一、数据存储与节省 “绝技” 1.1. 传感器数据存储挑战 1.2. 位运算解决方案 1.2.1. 数据整合 1.2.2. 数据提取 1.3. 收益分析 二、硬件控制 “精准操纵术” 2.1. 位运算操控硬件寄存器的实例 2.2. 位运算在硬件控制中的优势 2.3. 电机驱动芯片寄存器控制示例 …

设置redis

1.https://github.com/tporadowski/redis/releases下载对应版本 解压 启动redis临时服务 在 redis 文件夹下 cmd 输入redis-server.exe redis.windows.conf 临时服务启动 从新打开一个cmd 运行redis-cli 输入ping 启动成功 命令行输入shutdown关闭服务 创建永久服务 在…

baomidou Mabatis plus引入异常

1 主要异常信息 Error creating bean with name dataSource 但是有个重要提示 dynamic-datasource Please check the setting of primary 解决方法&#xff1a;增加 <dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-sp…

排序学习整理(1)

1.排序的概念及运用 1.1概念 排序&#xff1a;所谓排序&#xff0c;就是使⼀串记录&#xff0c;按照其中的某个或某些关键字的大小&#xff0c;递增或递减的排列起来的操作&#xff0c;以便更容易查找、组织或分析数据。 1.2运用 购物筛选排序 院校排名 1.3常见排序算法 2.实…