Matlab输出太多了

时间:2013-04-15 13:07:48

标签: matlab return-value

程序myfile.m读取一个txt文件,其中包含总共25个名称和数字,如

为例:

John doughlas 15986

Filip duch 357852

等等。

程序将它们转换为

15986 Doughlas John
357852 duch Filip 

这是没有功能的,我得到的输出太多了。

Error message:
Error using disp
Too many output arguments.

Error in red4 (line 26)
  array = disp(All);

以下原始代码:

function array = myfile(~) 
if nargin == 0 
dirr = '.';
end
answer = dir(dirr);  
k=1;
while k <= length(answer) 
    if answer(k).isdir 
        answer(k)=[]; 
    else
        filename{k}=answer(k).name;
        k=k+1;
    end
 end
chose=menu( 'choose file',filename);
namn = char(filename(chose));  
fid = fopen(namn, 'r');    
R = textscan(fid,'%s %s %s');  
x=-1;                                            
k=0;                                               
while x <= 24                                  
      x = k + 1;                                    
      All = [R{3}{x},'   ',R{1}{x},' ',R{2}{x}];
      disp(All)                                     
      k = k + 1;                                   
end                                                
fclose(fid);

现在我从functions这样的人和网站得到了许多好的答案,但是我不能像上面那样用函数得到结果。

我尝试过将它们组合起来并得到一些结果:

y = 15986 & [a,z,b] = myfile
y = 25 & myfile = x
y = numbers name1,2,3,4 and so one & myfile = fprintf(All)
y =                       & I used results().namn, 
numbers name 1            & results().id, results().lastname
y =
numbers name 2 and so on.

我想要的结果是:

y = myfile
y =
15986 Doughlas John
357852 duch Filip 

更新:改变它就像Eitan T说的那样,但没有像上面那样得到结果。

得到了结果:

'John doughlas 15986'

'Filip duch 357852'

function C = myfile()                            
 if nargin == 0 
    dirr = '.';
end
answer = dir(dirr); 
k=1;
while k <= length(answer)   
    if answer(k).isdir 
        answer(k)=[]; 
    else
        filname{k}=answer(k).name;
        k=k+1;
    end
end
chose=menu( 'choose',filname); 
name = char(filname(chose)); 
fid = fopen(name, 'r');
C = textscan(fid, '%s', 'delimiter', '');
C = regexprep(C{1}, '(\w+) (\w+) (\w+)', '$3 $2 $1');
fclose(fid); 

1 个答案:

答案 0 :(得分:1)

为什么要使用循环?使用textscan一次阅读这些行,并使用regexprep来操作单词:

fid = fopen(filename, 'r');
C = textscan(fid, '%s', 'delimiter', '');
C = regexprep(C{1}, '(\w+) (\w+) (\w+)', '$3 $2 $1')
fclose(fid);

结果是一个单元格数组C,每个单元格存储一行。对于您的示例,您将获得2×1单元阵列:

C = 
    '15986 doughlas John'
    '357852 duch Filip'

我不确定你想用它做什么,但如果你提供更多细节,我可以进一步改善我的答案。

希望这有帮助!