Matlab文件及文件夹操作典型代码(收录)

一:文件移动\复制

movefile

% 从father目录中复制指定类型的文件到目录s中

father='H:前期测试3'; %指定类型的文件所在的目录
s='H:前期测试3.3'; %复制文件的目标目录
subDir=dir(father); %求目录的子目录
len = length(subDir); %求子目录的长度
disp('begin copy files..');
for i=3:len
    imgNames = dir(strcat(father,subDir(i).name,'','*.JPEG'));
    a=[s,subDir(i).name,''];
    mkdir([s,subDir(i).name])
    for j=1:20 %复制的文件个数
        movefile([father,subDir(i).name,'',imgNames(j).name],a);
    end
end
disp('end');
end

copyfile

% 从father目录中复制指定类型的文件到目录s中
father='H:前期测试3'; %指定类型的文件所在的目录
s='H:前期测试3.3'; %复制文件的目标目录
subDir=dir(father); %求目录的子目录
len = length(subDir); %求子目录的长度
disp('begin copy files..');
for i=3:len
    imgNames = dir(strcat(father,subDir(i).name,'','*.JPEG'));
    a=[s,subDir(i).name,''];
    mkdir([s,subDir(i).name])
    for j=1:20 %复制的文件个数
        copyfile([father,subDir(i).name,'',imgNames(j).name],a);
    end
end
disp('end');
end
  1. movefile和copyfile的重要区别
clear  
clc    
cd('C:\Documents and Settings\Administrator\桌面\matlab\test'); 
% 设置当前目录  
%  此时test文件夹中有:文件夹1, 文件夹2, 文件1.txt, 文件2.txt    
movefile('1.txt', '11.txt');  % 把1.txt剪切成11.txt(1.txt不存在了)
%实际上相当于改名  
copyfile('2.txt', '22.txt');  % 把2.txt复制成22.txt(2.txt依然存在)    
movefile('11.txt', '1');      % 把11.txt剪切到文件夹1中  
copyfile('22.txt', '2');      % 把22.txt复制到文件夹2中  
  • 指定路径下 单个文件夹data中所有图像文件
file_path ='.\data\';   % 图像文件夹路径
img_path_list = dir(strcat(file_path,'*.jpg'));%获取该文件夹中所有jpg格式的图像
img_num = length(img_path_list);%获取图像总数量
if img_num > 0 %有满足条件的图像
        for j = 1:img_num %逐一读取图像
            image_name = img_path_list(j).name;% 图像名
            image =  imread(strcat(file_path,image_name));
            fprintf('%d %d %s\n',i,j,strcat(file_path,image_name));% 显示正在处理的图像名
            %图像处理过程 省略
        end
end

注: 上述的代码只能读取data文件夹中的图像,假设data中包含子文件夹,不能读取子文件夹中的图像。

三、多种功能代码

  1. 指定路径下 多个文件夹中所有图像
    该代码可以读取文件夹data中,及data的所有子文件夹中的图像。
p = genpath('.\data');% 获得文件夹data下所有子文件的路径,这些路径存在字符串p中,以';'分割
length_p = size(p,2);%字符串p的长度
path = {};%建立一个单元数组,数组的每个单元中包含一个目录
temp = [];
for i = 1:length_p %寻找分割符';',一旦找到,则将路径temp写入path数组中
    if p(i) ~= ';'
        temp = [temp p(i)];
    else 
        temp = [temp '\']; %在路径的最后加入 '\'
        path = [path ; temp];
        temp = [];
    end
end  
clear p length_p temp;
%至此获得data文件夹及其所有子文件夹(及子文件夹的子文件夹)的路径,存于数组path中。
%下面是逐一文件夹中读取图像
file_num = size(path,1);% 子文件夹的个数
for i = 1:file_num
    file_path =  path{i}; % 图像文件夹路径
    img_path_list = dir(strcat(file_path,'*.jpg'));
    img_num = length(img_path_list); %该文件夹中图像数量
    if img_num > 0
        for j = 1:img_num
            image_name = img_path_list(j).name;% 图像名
            image =  imread(strcat(file_path,image_name));
            fprintf('%d %d %s\n',i,j,strcat(file_path,image_name));% 显示正在处理的路径和图像名
            %图像处理过程 省略
        end
    end
end
  1. matlab中读取一行多个字符的文本
fid = fopen('');
while ~feof(fid)
    tline=fgetl(fid);
    [row col] = size(tline);
    print   = findstr(tline,'print');
    vein    = findstr(tline,'vein') ;
    user_id = findstr(tline,'user_id');
    p_value = str2num(tline(1,print+6:vein-2));
    v_value = str2num(tline(1,vein+5:user_id-2));
    plot(p_value,v_value,'r*');
end;
  1. matlab读取文档后截取特定字符
fid = fopen('D:\360Downloads\11\result.txt');
tline=fgetl(fid); 
[row col] = size(tline);
print   = findstr(tline,'print');
vein    = findstr(tline,'vein') ;
user_id = findstr(tline,'user_id:44 ');
p_value = str2num(tline(1,print+6:vein-2));
v_value = str2num(tline(1,vein+5:user_id-2));
  1. matlab新建文件夹及copy文件
clc ;
clear ;
for k=1:50
failname = dir('C:\Documents and Settings\Administrator\桌面\users\*.*') ;
[row col ] = size(failname);
for i =3:row    
    path = ['C:\Documents and Settings\Administrator\桌面\users\' failname(i).name] ;
    str = ['ui_' num2str(8*(k-1)+i-2)];
   savepath = ['C:\Documents and Settings\Administrator\桌面\usersfft2\' str] ; 
    copyfile(path,savepath);    
end;
end;
figure(1)
  1. matlab copy整个文件夹及以下内容
[row col ] = size(failname);
for i = 1:row        
path = failname{i} ;    
len = length(path);    
startpoint = len ;    
while(path(startpoint)~='\')        
startpoint = startpoint - 1 ;           
end;    
str = [] ;    
for i = startpoint+1:len       
str = [str path(i)] ;    
end   
savepath = ['D:\failimage\' str] ;     
copyfile(path,savepath);    
end;
figure
  1. matlab中cell的读取
names={'fyc','hy','ljg','lqf','lsl','ml','nhz','rj','syj','wl','wq','wyc','xch','xxj','yjf',
'zc','zdx','zjg','zl','zyf'};
len_names=length(names);
for i=1:len_name
surl=strcat('D:\GaitDatasetA-silh\silhouettes\',names(i),'\00_1');
url=url{1};

cell类型转换为string类型end
正如上面所示的一样,url调用strcat('D:\GaitDatasetA-silh\silhouettes',names(i),'\00_1');得到的是一个cell类型的变量,此时需要对url做一些变换就可以了,使用url=url{1};就搞定了!

  1. matlab读文档中的字符
clc
filename =fopen('E:\\filename.txt','r');%打开当前目录下的文档shiyan.txt里面存的是4*3数组
fid = fgetl(filename);
image1=imread(fid); 
fd=fopen('E:\\points.txt','r');%//打开当前目录下的文档shiyan.txt里面存的是4*3数组
A=fscanf(fd,'%f');%//读取这12个数据,保存在向量A中
for j=1:4     
for i=1:2       
B(j,i)=A((j-1)*2+i);%//转移到4*3矩阵B中     
end;   
end;
figure(1)subplot(1,2,2);
imshow(image1);
hold onfor j=1:4    
plot(B(j,1),480-B(j,2),'*');
end;
hold off; 
filename =fopen('E:\\filename_ir.txt','r');%打开当前目录下的文档shiyan.txt里面存的是4*3数组
fid = fgetl(filename);
image1=imread(fid); 
fd=fopen('E:\\points_ir.txt','r');%//打开当前目录下的文档shiyan.txt里面存的是4*3数组
A=fscanf(fd,'%f');%//读取这12个数据,保存在向量A中
   for j=1:4     
     for i=1:2       
       B(j,i)=A((j-1)*2+i);%//转移到4*3矩阵B中     
     end;   
   end;
subplot(1,2,1);imshow(image1);
hold onfor j=1:4    
plot(B(j,1),480-B(j,2),'*');
end;
hold off;
  1. 在matlab运算中使用未知字符
    可以先用syms声明该字符,然后就可以在计算中使用该字符,例如:
>> syms a;
>> b=[cos(a) sin(a);-sin(a) cos(a)] 
b = 
[  cos(a),  sin(a)]
[ -sin(a),  cos(a)]  
>> inv(b) 
ans = 
[  cos(a)/(cos(a)^2+sin(a)^2), -sin(a)/(cos(a)^2+sin(a)^2)]
[  sin(a)/(cos(a)^2+sin(a)^2),  cos(a)/(cos(a)^2+sin(a)^2)]
  1. 将采到的样本按用户名重新存储
clc ;
folder_path = 'G:\1\';save_path = 'G:\1_rename\' ;
folders = dir(folder_path);
[row_folder col_folder] = size(folders);
for i=3:row_folder
    tmp_folderpath = [folder_path folders(i).name] ;
    tmp_folderpath = [tmp_folderpath '\'] ;
    info_path = [tmp_folderpath 'user.info'] ;
    fid  = fopen(info_path,'rb');
    while ~feof(fid)
        tline=fgetl(fid);
        t = findstr(tline,'caption');
        if(t)
            [row1 col1] = size(tline);
            tt = tline(9:col1);
            save_path1 = [save_path tt] ;%新的文件夹名
             save_path1 =[save_path1 '\'] ;%新的文件夹名
            break;
        end;
    end;
    fclose(fid);        %%%%%copy 文件
    source_path = [tmp_folderpath 'sample\'] ;
     copyfile(source_path,save_path1);
%     tmp = [source_path '*.bmp'] ;
%     tmp2 = dir(tmp);
%     [row1 col1] = size(tmp2) ;
%     for j=1:row1
%         source_path = [source_path tmp2(j).name] ;
%         savepath1 = [savepath tmp2(j).name] ;
%         copyfile(source_path,savepath1);   
%     end;
end;

[Ref] (http://blog.csdn.net/flyingworm_eley/article/details/6644968#)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容