程序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);
答案 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'
我不确定你想用它做什么,但如果你提供更多细节,我可以进一步改善我的答案。
希望这有帮助!