python将YUV420P文件转PNG图片格式的两种方法
作者:遇见YY 发布时间:2021-09-04 10:06:10
标签:python,YUV420P,PNG
方法一:
import os
import cv2 as cv
import numpy as np
# 读取yuv420p的一帧文件,并转化为png图片
if __name__ == '__main__':
filepath = 'one_frame_of_highway.yuv'
binfile = open(filepath, 'rb')
size = os.path.getsize(filepath)
image_width = 352
image_hight = 288
image_y = [[0] * image_width for i in range(image_hight)]
image_u = [[0] * image_width for i in range(image_hight)]
image_v = [[0] * image_width for i in range(image_hight)]
for r in range(image_hight):
for c in range(image_width):
image_y[r][c] = binfile.read(1)[0]
Image_Y = np.array(image_y)
for r in range(int(image_hight / 2)):
for c in range(int(image_width / 2)):
pixel = binfile.read(1)[0]
image_u[2 * r + 0][2 * c + 0] = pixel
image_u[2 * r + 1][2 * c + 0] = pixel
image_u[2 * r + 0][2 * c + 1] = pixel
image_u[2 * r + 1][2 * c + 1] = pixel
Image_U = np.array(image_u)
for r in range(int(image_hight / 2)):
for c in range(int(image_width / 2)):
pixel = binfile.read(1)[0]
image_v[2 * r + 0][2 * c + 0] = pixel
image_v[2 * r + 0][2 * c + 1] = pixel
image_v[2 * r + 1][2 * c + 0] = pixel
image_v[2 * r + 1][2 * c + 1] = pixel
Image_V = np.array(image_v)
binfile.close()
compose = np.array([Image_Y, Image_V, Image_U]).transpose([1, 2, 0]).astype(np.uint8)
Image = cv.cvtColor(compose, cv.COLOR_YUV2RGB)
cv.imwrite("one_frame_of_highway.yuv.png", Image)
方法二:
ffmpeg -s 352x288 -i one_frame_of_highway.yuv one_frame_of_highway.png
highway视频网址:http://trace.eas.asu.edu/yuv/index.html
附录:
将yuv文件转化为一帧帧yuv文件
#include <stdio.h>
#include <fcntl.h>
#include <zconf.h>
#include <stdint.h>
#include <strings.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/stat.h>
int File_Size(int fd) {
struct stat st;
fstat(fd, &st);
return st.st_size;
}
int Frame_Size_Of_Cif() {
int width = 352;
int heigh = 288;
int Y_SIZE = width * heigh;
int U_SIZE = Y_SIZE / 4;
int V_SIZE = Y_SIZE / 4;
int Frame_SIZE = Y_SIZE + U_SIZE + V_SIZE;
return Frame_SIZE;
}
int Frames_Of_Cif_File(int fd) {
if (fd < 0) {
printf("Invalid FD!");
return -1;
}
int Frame_SIZE = Frame_Size_Of_Cif();
int fd_size = File_Size(fd);
return fd_size / Frame_SIZE;
}
void Abstract_Frame_From_CIF_File(int fd,char *Path_And_Prefix_Img,int Len) {
int Frame_SIZE = Frame_Size_Of_Cif();
char file[128];
memset(file,0,128);
memcpy(file,Path_And_Prefix_Img,Len);
uint8_t buf[Frame_SIZE];
int ret = -1;
int frames = 0;
while ((ret = read(fd, buf, Frame_SIZE))) {
frames += 1;
uint64_t len = strlen(file);
sprintf(file + len, "%d", frames);
len = strlen(file);
sprintf(file + len, "%s", ".yuv");
int fdw = open(file, O_RDWR | O_CREAT, 0777);
write(fdw, buf, ret);
memset(file,0,128);
memcpy(file,Path_And_Prefix_Img,Len);
close(fdw);
}
printf("Abstract %d frames!\n", frames);
}
int main() {
int fd = open("./yuv420p_352x288.yuv", O_RDONLY);
Abstract_Frame_From_CIF_File(fd,"/home/liu/Frames/Frames_",strlen("/home/liu/Frames/Frames_"));
close(fd);
return 0;
}
来源:https://www.cnblogs.com/iuyy/p/14238301.html


猜你喜欢
- 1. auth介绍Django 自带一个用户验证系统。它负责处理用户账号、组、权限和基于cookie的用户会话。认证系统由以下部分
- 相对于Firefox2来说,Firefox3除了采用全新的Gecko 1.9引擎外,在性能、稳定性和安全性方面进行许多改进,在我们最关心的对
- 本文介绍了目前6种比较常用的进度条,让大家都能直观地看到脚本运行最新的进展情况1.普通进度条在代码迭代运行中可以自己进行统计计算,并使用格式
- sysbench是一个模块化的、跨平台、多线程基准测试工具,主要用于评估测试各种不同系统参数下的数据库负载情况。关于这个项目的详细介绍请看:
- 一图胜“十”言:SQL Server 数据库总结 一个大概的总结 经过一段时间的学习,也对数据库有了一些认识。 数据库基本是由表,关系,操作
- 看代码 <?php header("Content-type: text/html; charset=utf-8"
- 那么在集合函数中它有什么用呢 ?假设数据库有一张表名为student的表。如果现在要你根据这张表,查出江西省男女个数,广东省男生个数,浙江省
- 不多说,直接上代码from hdfs import Clientimport pandas as pdHDFSHOST = "ht
- Python----OS 文件目录处理import osimport time# 获取当前文件的绝对路径dir_1 = os.path.ab
- python脚本实现xlsx文件解析,供大家参考,具体内容如下环境配置:1.系统环境:Windows 7 64bit 2.编译环境:Pyth
- 是否了解线程的同步和异步?线程同步:多个线程同时访问同一资源,等待资源访问结束,浪费时间,效率低线程异步:在访问资源时在空闲等待时同时访问其
- 写了一个练手的爬虫...在输出的时候出现了让人很不愉♂悦的问题像这样:令人十分难受啊!#--------------------------
- 决策树模型  决策树(decision tree)是一种基本的分类与回归方法。 &am
- 因项目需要根据指定格式的文件生成XML标注文件,可以方便使用LabelImg打开进行编辑和查看。其原始文件默认使用逗号进行分隔,如下
- 我最近在参与Python字节码相关的工作,想与大家分享一些这方面的经验。更准确的说,我正在参与2.6到2.7版本的CPython解释器字节码
- 实例如下所示:import numpy as npimport pandas as pddata = {'city': [&
- 1.基于rbac的权限管理RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联
- 本文仅作为基本操作流程的记录,不进行细节描述一、环境安装1、安装Pycharm在官网上下载最新版本Pycharm安装即可2、安装pyQT5p
- axios是通过Promise实现对ajax技术的一种封装,就像jquery对ajax的封装一样,axios回来的数据是promise,aj
- 外键在 MySQL 中,表有两种引擎,一种是 InnoDB ,另外一种是 myisam 。如果使用的是 InnoDB 引擎,是支持外键约束的