雅荷心语博客
雅荷心语
心之所向便是光
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 关注本站
    • 微信
    • 微博
    • 腾讯微博
    • Twitter
    • Facebook
    • RSS订阅
Hi, 请登录     我要注册     找回密码

使用 python 给音频增加水印,剪辑压缩后不丢失!

2024-12-23 分类:后端之路 阅读(223) 评论(0)

直接上代码:

编码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import numpy as np
import soundfile as sf
from scipy.fftpack import dct, idct
 
 
def embed_watermark(audio_file, watermark, output_file):
    # 读取音频文件
    audio_data, sample_rate = sf.read(audio_file)
 
    # 进行 DCT 变换
    dct_data = dct(audio_data, type=2, norm='ortho')
 
    # 确保水印长度不超过 DCT 数据长度
    if len(watermark) > len(dct_data):
        raise ValueError("Watermark is longer than the DCT data.")
 
    # 嵌入水印
    for i in range(len(watermark)):
        # 在 DCT 系数中嵌入水印(简单加法)
        if watermark[i] == 1:
            dct_data[i] += 0.1  # 增加值
        else:
            dct_data[i] -= 0.1  # 减少值
 
    # 进行逆 DCT 变换
    watermarked_audio = idct(dct_data, type=2, norm='ortho')
 
    # 确保音频数据在有效范围内
    watermarked_audio = np.clip(watermarked_audio, -1.0, 1.0)
 
    # 导出带水印的音频
    sf.write(output_file, watermarked_audio, sample_rate)
 
 
def main():
    original_audio_file = 'original_audio.mp3'  # 原始音频文件路径
    watermark = [1, 0, 1, 1, 0, 1, 0, 1]  # 示例水印(可以是二进制数据)
    output_audio_file = 'watermarked_audio.mp3'  # 输出文件路径
    embed_watermark(original_audio_file, watermark, output_audio_file)
 
 
if __name__ == "__main__":
    main()

 

解码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import numpy as np
import soundfile as sf
from scipy.fftpack import dct
 
def extract_watermark(watermarked_audio_file, watermark_length):
    # 读取带水印的音频文件
    watermarked_audio_data, sample_rate = sf.read(watermarked_audio_file)
 
    # 进行 DCT 变换
    dct_data = dct(watermarked_audio_data, type=2, norm='ortho')
 
    # 提取水印
    extracted_watermark = []
    for i in range(watermark_length):
        # 检查 DCT 系数的变化
        if dct_data[i] > 0:  # 假设嵌入时增加了值
            extracted_watermark.append(1)
        else:  # 假设嵌入时减少了值
            extracted_watermark.append(0)
 
    return extracted_watermark
 
def main():
    watermarked_audio_file = 'watermarked_audio3.mp3'  # 带水印的音频文件路径
    watermark_length = 8  # 水印长度(与嵌入时一致)
 
    extracted_watermark = extract_watermark(watermarked_audio_file, watermark_length)
    print("Extracted Watermark:", extracted_watermark)
 
if __name__ == "__main__":
    main()

 

 

 

喜欢 (1) 赏 讨厌 (0)
分享到:更多 ()

相关推荐

  • 将docker安装到D盘或者其他目录
  • 如何使用 nodejs 下载一个 wav 音频
  • macOS 对 Demucs 的支持
  • edge-tts 初体验
  • 联盟数据查询示例
  • 科学上网记录
  • 在浏览器内使用obs-websocket-js控制obs录屏
  • 部署多态 MySQL 服务器时保持数据一致性方案
关于我

小天明 北京·朝阳 前端搬砖工程师

碎碎念):(来自公众号)

热门文章

  • 踩坑记录——iphone上safari开启隐身模式时localStorage变为只读-雅荷心语博客踩坑记录——iphone上safari开启隐身模式时localStorage变为只读2017-02-21评论(4)
  • 程序员是怎样一群人-雅荷心语博客程序员是怎样一群人2015-12-08评论(3)
  • 百度你个大毒瘤 - 吐糟博客这几天打不开事情-雅荷心语博客百度你个大毒瘤 – 吐糟博客这几天打不开事情2015-12-28评论(2)
  • PHP 非对称加密 openssl 加密及解密方法-雅荷心语博客PHP 非对称加密 openssl 加密及解密方法2016-05-17评论(2)
  • PHPStorm10 下载安装破解汉化-雅荷心语博客PHPStorm10 下载安装破解汉化2015-12-15评论(2)
2025年7月
一 二 三 四 五 六 日
« 六    
 123456
78910111213
14151617181920
21222324252627
28293031  

最新评论

  • 前端小武 8年前 (2017-04-06)说:
    我看到了layer
  • 丁艳平 8年前 (2017-03-03)说:
  • Dawn 9年前 (2016-09-16)说:
    call_user_func_array最后的例子是错哦,你用bc方法去调用类里 另外一个方法就知道问题所在了。情况1.调用非静态方法 第一个参数应该传[类的实例,调用方法] (既然有类实例了直接-&
  • Dawn 9年前 (2016-06-21)说:
    tp框架设置了全局捕获异常的,这也没什么。坑的是 他捕获了异常。然后全部返回404。。。不知道的 还以为自己网站被删除了
  • Dawn 9年前 (2016-05-17)说:
    构造函数里的判断 用异常机制可能更好一些

其他类型

  • 芊云全景
  • 配音兔AI配音神器

博客类型

  • 芊云全景
  • 配音兔AI配音神器

左邻右舍

  • 易水寒
  • 楼教主
  • 芊云全景
  • 贤心
  • 配音兔AI配音神器

雅荷心语博客 -心之所向便是光

联系我们关于我们

© 2025 雅荷心语博客   网站地图