【MATLAB】读取视频,提取视频每一帧特征值并存成EXCEL,并保存个别图像

1、读取视频

2、对视频尺寸进行预处理到4K

3、分析每帧特征

4、将每帧特征存储到Excel表格

5、将特殊画面存进对应文件夹里

matlab 复制代码
clear ;close all;clc;

%初始化
fileName = 'grayscale.mp4'; %视频名称
filepath=strcat('./input/',fileName);
obj = VideoReader(filepath);
numFrames = obj.NumFrames;% 帧的总数
h=obj.Width;
v=obj.Height;

vh_th=0.7;%16:9差异设置,abs(h/v-16/9)<vh_th不加黑框

frame_UD=zeros(2160,3840,3,'uint8');
YCbCr=zeros(2160,3840,'double');
frame_Falg=zeros(numFrames,4,'double');
APL=zeros(1,1,'double');

savepath=strcat('./output/',fileName(1:end-4));
if ~exist(savepath, 'dir')
   savepath_status = mkdir(savepath);%如果路径不存在则新建一个
end


for k = 1 : numFrames% 读取数据
 
    frame = read(obj,k);
    %视频大小预处理
    if abs(h/v-16/9)<vh_th
        frame_UD=imresize(frame,[2160,3840],'bilinear');%16:9插值到4K
        black_add=0;
    else
        if h>v
            frame_new_h=imresize(frame,[v,3840],'bilinear');
            start=fix((2160-v)/2);
            frame_UD(start:start+v-1,:,:)=frame_new_h;
            black_add=(2160-v)*3840;

        else
            frame_new_v=imresize(frame,[2160,h],'bilinear');
            start=fix((3840-h)/2);
            frame_UD(:,start:start+h-1,:)=frame_new_v;
            black_add=(3840-h)*2160;
        end
    end

    %APL generate
    YCbCr=0.299*frame_UD(:,:,1)+0.587*frame_UD(:,:,2)+0.114*frame_UD(:,:,3);
    APL=mean2(YCbCr)/255;

    %0~4pixel count
    if APL>=0 && APL <0.2
        Gray_range=4;
    elseif APL>=0.2 && APL <0.4
        Gray_range=5;
    elseif APL>=0.4 && APL <0.6
        Gray_range=6;
    elseif APL>=0.6 && APL <0.8
        Gray_range=8;
    elseif APL>=0.8 && APL <=1
        Gray_range=10;
    else
        ray_range=10;
    end
    
    Gray_cnt=fix(sum(sum(sum(frame_UD < Gray_range)))/3);
   if  Gray_cnt>(8295+black_add)
       grayscale_gradient_Flag=1;
   else
       grayscale_gradient_Flag=0;
   end


 frame_Falg(k,1)=k;
 frame_Falg(k,2)=APL;
 frame_Falg(k,3)=Gray_cnt;
 frame_Falg(k,4)=grayscale_gradient_Flag;

 % imshow(frame_UD);%显示帧

 if grayscale_gradient_Flag==1
 WritePath=strcat('./output/',fileName(1:end-4),'/',num2str(k),'.bmp');  
 imwrite(frame_UD,WritePath);% 保存帧
 end

end


Writepath_excel=strcat('./output/',fileName(1:end-4),'_analysis.xlsx');
%方式1,速度慢
%Writdetail_excel = {'Frame num', 'APL', 'Gray count','grayscale_like' };
% for k=1:numFrames
% Writdetail_excel (k+1,:)={frame_Falg(k,1),frame_Falg(k,2),frame_Falg(k,3),frame_Falg(k,4)};
% end

%方式2,矩阵操作加速
 Writdetail_excel (1,:)={'Frame num', 'APL', 'Gray count','grayscale_like' };
 Writdetail_excel (2:numFrames+1,:)=num2cell(frame_Falg(:,:));


writecell(Writdetail_excel,Writepath_excel);
disp('Analysis Done!');
相关推荐
foundbug9998 小时前
直流电机 PID 速度控制 MATLAB 仿真程序
开发语言·matlab
yuan1999710 小时前
欧拉梁静力与屈曲计算的 MATLAB 实现(有限差分法 + 解析解)
开发语言·算法·matlab
昨日之日200610 小时前
Higgs Audio v3 - 超自然多语言情感TTS,一键克隆声音 一键整合包下载
人工智能·音视频
wearegogog12313 小时前
基于光流算法的运动物体检测与光流场分析(MATLAB实现)
开发语言·算法·matlab
EasyDSS13 小时前
跳出播放器思维,私有化视频会议平台EasyDSS一站式视频平台,重塑企业私有化融媒体/视频会议系统需求!
音视频·媒体
声光界13 小时前
《星闪无线短距通信使能智能音频》
音视频
吾名招财15 小时前
视频+全景视频多视角快速抽帧工具(可免费使用)
音视频·视频抽帧·全景视频
王木风15 小时前
Spring Boot + LLM 工程化:把短视频流水线拆成 16 个独立角色的踩坑记录
人工智能·spring boot·后端·开源·新媒体运营·音视频·agent
88号技师15 小时前
2026年2月一区SCI-交叉传播优化算法Propagation Alongside Crossover-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
ytttr87316 小时前
航天器姿态控制 MATLAB 仿真程序
开发语言·matlab