天天看点

如何在matlab里批量将JPG格式图片转成MAT格式文件?

http://blog.csdn.net/yongjiankuang/article/details/72824081

考虑到很多人遇到图片转成.mat文件的需要,本文特此贴出一次性将多个文件夹下的图片转化为.mat,同时给数据打上标签,希望能够帮到大家!

%这里是主函数:命名为readImg.m;

[plain]  view plain  copy

  1. clc;clear;  
  2. %---read_image;  
  3. filepath = 'G:\人脸重建\data\src_all\';%图片路径可以根据自己需要修改;  
  4. pic = '*jpg';%图片格式,根据自己的图片格式进行修改;  
  5. database = build_database_src(filepath,pic);  

%build_database_src.m子函数;

[plain]  view plain  copy

  1. function database = build_database_src(rt_data_dir,suffix)  
  2. fprintf('dir the database');  
  3. subfolders = dir(rt_data_dir);  
  4. database = [];  
  5. database.imnum = 0;  
  6. database.cname = {};  
  7. database.label = [];  
  8. database.path = [];  
  9. database.nclass = 0;  
  10. label = 0;  
  11. k = 1;  
  12. src_x = [];  
  13. src_y = [];  
  14. for ii = 1 : length(subfolders)  
  15.     subname = subfolders(ii).name;  
  16.     if ~strcmp(subname,'.') & ~strcmp(subname,'..')  
  17.         database.nclass = database.nclass + 1;  
  18.         database.cname{database.nclass} = subname;  
  19.         frames = dir(fullfile(rt_data_dir,subname,suffix));  
  20.         c_num = length(frames);  
  21.         database.imnum = database.imnum + c_num;  
  22.         database.label = [database.label;ones(c_num,1) * database.nclass];  
  23.         label = numel(database.cname);  
  24.         for jj = 1 : c_num  
  25.             fprintf('folder : %d , num : %d \n',ii - 1,jj);  
  26.             kk1 = frames(jj).name;%显示具体图片名;  
  27.             c_path = fullfile(rt_data_dir,subname,frames(jj).name);  
  28.             database.path = [database.path,c_path];  
  29.             img = imread(database.path);%读取图片;  
  30.             im = imresize(img,[64,64]);%设置图片大小;  
  31.             if(length(size(im)) == 3)%如果是彩色图进行灰度化(根据个人需要);  
  32.                 gray = rgb2gray(im);  
  33.             else  
  34.                 gray = im;  
  35.             end  
  36.             gray = double(gray) / 255;%对图片数据做归一化(根据个人需要);  
  37.             database.path = [];  
  38.             src_x(:,:,k) = gray;%存储图像数据;  
  39.             src_y(1,k) = label;%给数据加标签;  
  40.             k = k + 1;  
  41.         end  
  42.     end  
  43. end  
  44. %保存转化好的.mat文件;  
  45. file = ['src_x.mat'];  
  46. save(file,'src_x','-mat');  
  47. file = ['src_y.mat'];  
  48. save(file,'src_y','-mat');  
  49. end  

我的路径:G:\人脸重建\data\src_all,如下所示:

运行程序可以看到生成两个.mat文件:

继续阅读