Video Python(Pyav)解碼二

在?PyAV?中,input_container.decode()?和?input_container.demux()?是兩種處理視頻流數據的不同方法,它們分別適用于不同的場景。下面通過代碼示例和對比來詳細說明它們的用法和區別。


1.?input_container.decode()

功能

  • 直接解碼:從容器中讀取數據包(Packet)并自動解碼成幀(Frame)。

  • 簡化流程:適合直接獲取可用的視頻/音頻幀,無需手動處理數據包和解碼器。

使用示例

python

import av# 打開輸入文件或流
input_container = av.open("input.mp4")# 選擇第一個視頻流
video_stream = input_container.streams.video[0]# 直接解碼幀(自動處理Packet→Frame)
for frame in input_container.decode(video_stream):# frame 是解碼后的視頻幀(av.VideoFrame)img = frame.to_ndarray(format="bgr24")  # 轉為OpenCV可用的numpy數組print("解碼幀:", frame.pts, frame.time_base)input_container.close()

適用場景

  • 需要直接獲取解碼后的幀(如視頻處理、AI推理)。

  • 不需要手動管理數據包(Packet)和解碼器(CodecContext)。


2.?input_container.demux()

功能

  • 解復用(Demux):從容器中提取原始數據包(Packet),但不自動解碼。

  • 手動控制:允許用戶自行管理解碼過程(如選擇是否解碼、跳過某些幀等)。

使用示例

python

import av# 打開輸入文件或流
input_container = av.open("input.mp4")# 選擇第一個視頻流
video_stream = input_container.streams.video[0]# 獲取數據包(Packet)
for packet in input_container.demux(video_stream):# packet 是未解碼的原始數據(av.Packet)if packet.is_corrupt:print("損壞的數據包,跳過")continue# 手動解碼(使用流的解碼器)for frame in packet.decode():# frame 是解碼后的視頻幀(av.VideoFrame)img = frame.to_ndarray(format="bgr24")print("解碼幀:", frame.pts, frame.time_base)input_container.close()

適用場景

  • 需要手動控制數據包(如過濾、選擇性解碼)。

  • 需要訪問原始?Packet?信息(如?ptsdtsflags)。

  • 適用于高級流處理(如轉碼、流分析)。


3. 核心區別對比

特性decode()demux()
輸出類型直接返回?Frame(已解碼)返回?Packet(未解碼)
是否自動解碼? 自動解碼? 需手動調用?packet.decode()
性能更高(PyAV內部優化)稍低(需手動管理)
靈活性較低(無法控制數據包)高(可過濾、跳幀、自定義解碼邏輯)
適用場景簡單幀處理(如AI推理、顯示)高級流處理(如轉碼、流分析)

4. 進階用法

(1) 僅解碼關鍵幀(I幀)

python

# 使用 demux() + 手動檢查關鍵幀
for packet in input_container.demux(video_stream):if packet.is_keyframe:  # 僅處理關鍵幀for frame in packet.decode():print("關鍵幀:", frame.pts)

(2) 跳幀處理(降低解碼負載)

python

frame_skip = 2  # 每2幀解碼1次
count = 0for packet in input_container.demux(video_stream):count += 1if count % frame_skip != 0:continue  # 跳過非目標幀for frame in packet.decode():print("解碼幀:", frame.pts)

(3) 提取原始H.264 NAL單元

python

for packet in input_container.demux(video_stream):# packet.data 是原始H.264數據(含SPS/PPS/幀數據)nal_type = packet.data[4] & 0x1F  # H.264 NAL單元類型print("NAL Type:", nal_type)

5. 總結

  • decode()

    • 推薦?大多數情況使用,代碼更簡潔,性能更好。

    • 適用于直接獲取幀(如OpenCV處理、AI模型輸入)。

  • demux()

    • 需要手動控制數據包時使用(如關鍵幀提取、流分析、自定義解碼邏輯)。

    • 適用于高級媒體處理(如轉碼、封裝格式分析)。

根據需求選擇合適的方法!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/89095.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/89095.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/89095.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

閑庭信步使用圖像驗證平臺加速FPGA的開發:第十六課——圖像五行緩存的FPGA實現

(本系列只需要modelsim即可完成數字圖像的處理,每個工程都搭建了全自動化的仿真環境,只需要雙擊top_tb.bat文件就可以完成整個的仿真,大大降低了初學者的門檻!!!!如需要該系列的工程…

頭文件與源文件及區別

使用場景上的區別頭文件:變量的聲明,函數的聲明,宏的定義,類的定義等。 源文件:變量的定義。函數的定義實現,類成員函數的定義實現等。這樣方便于我們去管理、規劃,更重要的是避免了重定義的問題…

圖機器學習(4)——圖機器學習與嵌入算法

圖機器學習(4)——圖機器學習與嵌入算法0. 前言1. 圖機器學習1.1 機器學習基本原理1.2 圖機器學習的獨特優勢2. 廣義圖嵌入問題3. 圖嵌入算法分類小結0. 前言 機器學習是人工智能的一個重要分支,它致力于讓系統能夠從數據中自主學習并持續優…

網絡基礎10--ACL與包過濾

一、ACL 定義與核心功能ACL(訪問控制列表)是通過規則匹配實現數據包過濾或分類的核心技術,廣泛應用于包過濾、NAT、QoS、路由策略等場景。其核心由規則條目組成,每條規則包含匹配條件(如源 / 目 IP、端口、協議&#x…

Web安全 - 基于 SM2/SM4 的前后端國產加解密方案詳解

文章目錄概述一、背景與法規要求二、算法選型三、核心流程四、前端實現要點(偽代碼)五、后端實現要點(偽代碼)六、公鑰存儲策略七、全流程示例圖八、總結與最佳實踐推薦概述 隨著信息安全法規日益嚴格,如《網絡安全法》《數據安全法》和等保…

ACL動態路由實驗全攻略:配置與安全實戰

實驗拓撲圖 實驗需求 步驟1.按照圖示配置IP地址2.按照圖示區域劃分配置對應的動態路由協議3.在R7上配置dhcp服務器,能夠讓pc可以獲取IP地址4.將所有環回宣告進ospf中,將環回17宣告進rip中,將rip路由引rospf中,ospf路由引.rip中5.要…

電動汽車制動系統及其工作原理

制動系統是實現車輛減速、停車功能的重要系統。電動汽車的制動系統按照制動實現方式分為機械制動和電機再生制動,機械制動根據制動力實現方式不同又可分為液壓機械制動系統、氣壓機械制動系統和電子機械制動系統。目前,電動汽車的制動系統實現一般為協調…

CentOS 7 Linux 離線安裝 docker-compose

CentOS 7 Linux 離線安裝 docker-compose 1. docker-compose 簡介 1.1. docker-compose 是什么? docker-compose 是 Docker 官方提供的工具,用于定義和運行多容器 Docker 應用程序。通過一個 YAML 文件(通常為 docker-compose.yml&#xf…

排序算法實戰(上)

一、引言在力扣刷題的旅程中,排序類題目是繞不開的重要板塊。今天就來分享兩道經典排序題——912. 排序數組和75. 顏色分類的解題思路與代碼實現,帶你深入理解排序算法在實際題目中的應用 。二、題目剖析與解題思路(一)912. 排序數…

python學智能算法(二十)|SVM基礎概念-感知機算法及代碼

引言 前序學習進程中,已經學習了超平面的基礎知識,學習鏈接為:超平面 在此基礎上,要想正確繪制超平面,還需要了解感知機的相關概念。 感知機 感知機是對生物神經網絡的模擬,當輸入信號達到感知機的閾值時…

操作HTML網頁

一、HTML網頁的介紹 HTML,即超文本標記語言(HyperText Markup Language),它不是一種編程語言,而是一種標記語言,用于描述網頁的結構。HTML 通過一系列標簽來定義網頁中的各種元素,如文本、圖片…

Django--03視圖和模板

Django–03視圖和模板 Part 3: Views and templates 本教程承接第二部分,我們將繼續開發投票應用,重點介紹 Django 的表單處理和通用視圖。 文章目錄Django--03視圖和模板前言概述一、編寫更多視圖二、編寫實際執行操作的視圖三、快捷方式:r…

《每日AI-人工智能-編程日報》--2025年7月15日

介紹:AI :英偉達恢復向中國銷售 H20 并推出新 GPU:7 月 15 日,英偉達官宣將恢復向中國銷售 H20,并推出全新的 NVIDIA RTX PRO GPU,其中 B30 性能約為 H20 的 75%,定價在 6500 至 8000 美元之間&…

C++STL-list

一.基礎概念相當于數據結構里面的雙向鏈表二.基礎操作1.list對象創建1. 默認構造函數list<int> l1;2. 初始化列表list<int> l2_1 { 9,8,7,6,5 };list<int> l2_2({ 9, 8, 7, 1, 5 });3. 迭代器list <int> l3(l2_1.begin(), l2_1.end());4. 全0初始化li…

【PTA數據結構 | C語言版】字符串插入操作

本專欄持續輸出數據結構題目集&#xff0c;歡迎訂閱。 文章目錄題目代碼題目 請編寫程序&#xff0c;將給定字符串 t 插入到另一個給定字符串 s 的第 pos 個字符的位置。 輸入格式&#xff1a; 輸入先后給出主串 s 和待插入的字符串 t&#xff0c;每個非空字符串占一行&#…

Postman + Newman + Jenkins 接口自動化測試

??親愛的技術愛好者們,熱烈歡迎來到 Kant2048 的博客!我是 Thomas Kant,很開心能在CSDN上與你們相遇~?? 本博客的精華專欄: 【自動化測試】 【測試經驗】 【人工智能】 【Python】 </

CAS單點登錄架構詳解

目錄 概述核心概念 TGC (Ticket Granting Cookie)TGT (Ticket Granting Ticket)ST (Service Ticket) 架構設計 整體架構存儲架構安全機制 工作流程 完整登錄時序流程步驟詳解 技術實現 會話管理數據同步問題最佳實踐 參考資料 概述 CAS (Central Authentication Service) 是…

C++中正則表達式詳解和實戰示例

C 中的正則表達式&#xff08;Regular Expression&#xff09;主要通過標準庫 <regex> 提供&#xff0c;能夠用于字符串匹配、查找、替換、驗證格式等。它在 C11 中首次引入&#xff0c;并在 C14 和 C17 中逐步完善。一、頭文件和命名空間 #include <regex> #inclu…

深入解析Avro、Protobuf與JSON:序列化技術的選擇與應用

在現代分布式系統和數據交換場景中&#xff0c;序列化技術是數據存儲、傳輸和通信的核心。本文深入探討三種主流序列化技術&#xff1a;Avro、Protobuf 和 JSON&#xff0c;從背景、特點、示例代碼&#xff08;Python&#xff09;、優勢及最佳實踐等多個維度進行對比分析&#…

Vue 中 effectScope() 的全面解析與實戰應用

一、effectScope 概述1.1 什么是 effectScopeeffectScope() 是 Vue 3.2 引入的核心 API&#xff0c;用于創建副作用作用域容器。它能夠將多個響應式副作用&#xff08;如 watch、watchEffect 和 computed&#xff09;組織在一起&#xff0c;實現統一的生命周期管理。1.2 核心價…