中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python怎么提取視頻中的音頻

發布時間:2022-01-26 09:49:07 來源:億速云 閱讀:183 作者:iii 欄目:開發技術

本篇內容介紹了“Python怎么提取視頻中的音頻”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

一、提取音頻

需要用到 python 的 moviepy 庫

moviepy的 github 地址:https://github.com/Zulko/moviepy

命令行 pip 安裝上 moviepy 即可!

pip install moviepy -i http://pypi.douban.com/simple --trusted-host pypi.douban.com

Python怎么提取視頻中的音頻

提取音頻:假設有一個 mp4 文件路徑為"D:pythonpycharm2020my_programvideo_process est_01.mp4",我們想提取其中的音頻保存到"D:pythonpycharm2020my_programvideo_processvst01.mp3",三行 Python 代碼實現如下:

import moviepy.editor as mpy


# 截取背景音樂
audio_background = mpy.AudioFileClip(r'D:pythonpycharm2020my_programvideo_process	est_01.mp4').subclip(1, 60)
audio_background.write_audiofile(r'D:pythonpycharm2020my_programvideo_processvst01.mp3')

執行上面的三行代碼,就會發現音頻文件已經成功提取到指定文件夾啦~ ~這里的視頻格式和音頻格式都支持其他格式,比如讀取 mp4 格式視頻,抽取其中的背景音樂保存為 MP3 格式音頻。

二、引力波繪制

Python怎么提取視頻中的音頻

數據來源:

  • http://python123.io/dv/grawave.html

  • http://python123.io/dv/H1_Strain.wav

  • http://python123.io/dv/L1_Strain.wav

  • http://python123.io/dv/wf_template.txt

從配置文檔中讀取時間相關數據

import numpy as np  # 科學計算所用的numpy庫
import matplotlib.pyplot as plt  # 繪圖所用的庫matplotlib
from scipy.io import wavfile  # 讀取波形文件所用的庫


rate_h, hstrain = wavfile.read(r"H1_Strain.wav", "rb")   # 讀取音頻文件
rate_l, lstrain = wavfile.read(r"L1_Strain.wav", "rb")
# reftime, ref_H1 = np.genfromtxt('GW150914_4_NR_waveform_template.txt').transpose()
reftime, ref_H1 = np.genfromtxt('wf_template.txt').transpose()  # 使用python123.io下載txt文件

構造應變數據

htime_interval = 1 / rate_h
ltime_interval = 1 / rate_l
fig = plt.figure(figsize=(12, 6))  # 創建大小為12*6的繪圖空間

# 丟失信號起始點
htime_len = hstrain.shape[0] / rate_h  # 讀取數據第一維的長度,得到函數在坐標軸上總長度
htime = np.arange(-htime_len / 2, htime_len / 2, htime_interval)  # (起點,終點,時間間隔)

使用來自 “H1” 探測器的數據作圖

plth = fig.add_subplot(221)  # 設置繪圖區域
plth.plot(htime, hstrain, 'r')  # 畫出以時間為x軸,應變數據為y軸的圖像,‘y'為黃色
plth.set_xlabel('Time (seconds)')
plth.set_ylabel('H1 Strain')
plth.set_title('H1 Strain')

繪制 L1 Strain 和Template

ltime_len = lstrain.shape[0] / rate_l
ltime = np.arange(-ltime_len / 2, ltime_len / 2, ltime_interval)
pltl = fig.add_subplot(222)
pltl.plot(ltime, lstrain, 'k')
pltl.set_xlabel('Time (seconds)')
pltl.set_ylabel('L1 Strain')
pltl.set_title('L1 Strain')

pltref = fig.add_subplot(212)
pltref.plot(reftime, ref_H1, 'purple')
pltref.set_xlabel('Time (seconds)')
pltref.set_ylabel('Template Strain')
pltref.set_title('Template')
fig.tight_layout()  # 自動調整圖像外部邊緣

保存并顯示圖像

plt.savefig("Gravitational_Waves_Original.png")  # 保存圖像為png格式
plt.show()
plt.close(fig)

“Python怎么提取視頻中的音頻”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

通城县| 莱西市| 托里县| 越西县| 杭锦旗| 陈巴尔虎旗| 永仁县| 东台市| 阜新| 深圳市| 平顶山市| 尚义县| 泸溪县| 赤峰市| 虞城县| 梓潼县| 兰坪| 桑植县| 康定县| 罗源县| 神农架林区| 盐城市| 新野县| 永川市| 通道| 张家口市| 陆良县| 恭城| 金湖县| 土默特左旗| 固安县| 曲阜市| 吉安市| 义乌市| 修水县| 高陵县| 安福县| 南投市| 丹巴县| 原平市| 民权县|