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

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

你可能感兴趣的:(神经网络,训练库处理)