利用AI大模型实现个性化视频配音

打造个性化AI视频配音

image

  最近,我萌生了拍摄短视频的念头,希望通过这个平台与大家分享一些AI技术的实际应用。

  然而,在准备过程中,我遇到了一个难题——配音。

  家里的环境嘈杂,收音设备也不够专业,这让在录制配音时感到非常难受。

  一开始,我考虑使用机器配音来解决这个问题。然而,当我试听了一些机器音色后,发现它们的机器感太重,完全不像人类的声音。

  这种效果无法满足我对配音的幻想,让我感到非常失望。我甚至一度想要放弃这个想法。

  然而,就在我准备放弃的时候,

  突然想到,既然AI大模型支持语音识别,那肯定也有语音合成的模型吧。

  于是,我开始在网上搜索相关的信息,最终在阿里云百炼平台上找到了

  通义千问-语音合成CosyVoice大模型。

image

  经过试听,发现多个音色都符合我的要求,完全可以作为视频的配音。

  这让我非常兴奋,终于找到了解决配音问题的方法。

  经过多次试听,最终选择了“龙小淳”作为视频的音色,因为它听起来既自然又亲切,非常适合我的短视频风格。

image

  在选择好音色后,我准备根据文本生成配音。最开始,我想到用百炼平台提供的“自定义文本试听”功能来生成音频文件。然而,我发现这个功能有一个很大的限制——它限制了生成的字数,无法满足中长视频的要求。

  这让我非常沮丧,开始寻找其他方法。

  就在我陷入困境的时候,突然想到可以用API来生成音频

  这样就不会有字数限制了。说干就干,我打开VSCode,开始写一段Python代码来生成音频。

  在编写代码的过程中,遇到了一些问题,通过查阅相关文档和搜索网上的解决方案,成功地解决了这些问题。

  最终,我完成了视频的配音,效果非常满意。

  通过这次经历,深刻体会到了AI技术的强大和便捷。不仅解决了配音问题,还让我学到了很多新的知识和技能。

  我相信,在未来的日子里,我会继续探索和应用AI技术,为大家带来更多有趣和有价值的内容。

  ‍

  附代码和本文章的音频

# coding=utf-8import dashscope
from dashscope.audio.tts_v2 import *# 将your-dashscope-api-key替换成您自己的API-KEY
dashscope.api_key = "your-dashscope-api-key"
# 语音模型
model = "cosyvoice-v1"
# 音色
voice = "longxiaochun"# 初始化
synthesizer = SpeechSynthesizer(model=model, voice=voice)
# 读取需要合成语音的文本文件
with open("1.txt", 'r', encoding='utf-8') as f:text_content = f.read()
# 开始合成语音
audio = synthesizer.call(text_content)
# 打印请求ID
print('requestId: ', synthesizer.get_last_request_id())
# 保存合成的语音到 合成结果.mp3 文件
with open('合成结果.mp3', 'wb') as f:f.write(audio)

  最后 欢迎关注公众号【AI技术开发者】

image

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

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

相关文章

【取证工具】Magnet AXIOM中文绿色版(更新8.4)

Magnet AXIOM取证工具介绍 Magnet AXIOM 是一款功能强大的数字取证工具,专为法律执行人员、调查员和安全专家设计,用于从各种数字设备中提取、分析和报告证据。AXIOM 提供了全面的取证支持,能够从电脑、移动设备、云端服务以及物联网设备中收集并分析数据。多平台支持 Magne…

介绍1个简单好用的英文文本翻转网站,关键还免费不用登录

输入英文,会 生成对应的翻转、反向、镜像、𝕆𝕦𝕥𝕝𝕚𝕟𝕖 𝔽𝕠𝕟𝕥、𝓒𝓾𝓻𝓼𝓲𝓿𝓮 𝓛𝓮𝓽𝓽𝓮𝓻𝓼的文本可以用于生成密码,聊天时发消息,猜字符的场景,欢迎使用和访问,简单免费,无需登录 比如你想她啦,不好意思说…

[Babel] Intro Babel - 01 Introduction

Babel介绍 Babel 是一个编译器,主要用于将最新的 JavaScript 代码转化为向后兼容的代码,以便在老版本的浏览器或环境中运行。 例如,你可能在开发时使用了 ES6、ES7 或者更高级的 JavaScript 特性,但是有些浏览器可能并不支持这些新特性,这时就可以用 Babel 来将代码转化为…

Babel Intro Babel - 01 Introduction

Babel介绍 Babel 是一个编译器,主要用于将最新的 JavaScript 代码转化为向后兼容的代码,以便在老版本的浏览器或环境中运行。 例如,你可能在开发时使用了 ES6、ES7 或者更高级的 JavaScript 特性,但是有些浏览器可能并不支持这些新特性,这时就可以用 Babel 来将代码转化为…

unordered_map-STL容器

时间复杂度和空间复杂度

2 应用层

2 应用层 2.1 网络应用原理 网络应用:能够运行在不同的端系统和通过网络彼此通信的程序。注:在端系统上运行,而不是在网络核心上运行。网络应用是计算机网络存在的理由。 2.1.1 应用体系结构(application architecture) 客户-服务器体系结构(client-server architecture)…

【内网穿透】概念、原理与实现方法

一、内网穿透简介 内网穿透是一种网络技术,它允许外部网络(如互联网)上的设备访问位于内部网络(例如公司或家庭局域网LAN)中没有直接公网IP地址的设备。这对于远程办公、云服务接入以及物联网设备管理等场景至关重要。 二、工作原理 内网穿透主要依赖于NAT(网络地址转换)…

数字电路课程笔记

1、数制与码制 补零 二进制和十六进制之间的转换: 整数部分:对于整数部分,您需要将二进制数从右往左,每四位一组。如果剩余的位数不足四位,就需要在左边补零,直到每组都有四位。小数部分:对于小数部分,您需要将二进制数从左往右,每四位一组。如果剩余的位数不足四位,…

unity里生成的.csproj和.sln :assembly definition

有一段时间一直没明白为啥有的时候第三方的package里的代码没法引用我们项目的,最近有点心得,记录下: 在创建unity项目的时候默认是创建一个解决方案就是以.sln为结尾的。默认开发时都在同一个解决项目里,所以不会出现相互引用不到的问题。当我们引用到第三方的package时就…

【前端框架】2025 React 状态管理终极指南!

全文约 10800 字,预计阅读需要 30分钟。 React 作为当下最受欢迎的前端框架,在构建复杂且交互丰富的应用时,状态管理无疑是至关重要的一环。从简单的本地状态,到能让多个组件协同工作的全局状态,再到涉及服务器通信、导航切换、表单操作以及持久化存储等不同场景下的状态管…

【搜索】多源BFS专题

跳马(多源BFS变种,每个起点有步数限制)补充几个测试样例 输入 3 2 . . 2 . . .输出 0输入 3 5 4 7 . 4 8 4 7 4 4 . 7 . . . .输出 17输入 3 4 . . . . . 2 . . . . . .输出 0输入 3 4 . . . . . 2 2 . . . . .输出 -1本题很坑爹的地方在于,输入的字符串还用空格分开,所以…

代码随想录算法训练营第四天 | 24. 两两交换链表中的节点、19. 删除链表的倒数第N个节点、160.链表相交、142.环形链表II

9-24.两两交换链表中的节点 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。示例 1:输入:head = [1,2,3,4] 输出:[2,1,4,3] 示例 2: 输入:head = [] 输出:[] 示例 3: 输入:he…