1
如果我們有 A = [100 -0.1 0]; B = [30 0.2 -2]; t1 ='文字1'; T2 =文本2'MATLAB fprintf增加指數位數
如何使用fprintf中,使保存在文件輸出將看起來像
100 -1.000E-0001 0.000E-0000 'text 1'
30 2.000E-0001 -2.000E-0000 'text 2'
如果我們有 A = [100 -0.1 0]; B = [30 0.2 -2]; t1 ='文字1'; T2 =文本2'MATLAB fprintf增加指數位數
如何使用fprintf中,使保存在文件輸出將看起來像
100 -1.000E-0001 0.000E-0000 'text 1'
30 2.000E-0001 -2.000E-0000 'text 2'
我把一個‘一班輪’(分佈在幾行以提高可讀性)它接受一個數組,一個數字格式和一個分隔符並返回所需的字符串。而當你發現了導致空白空間的標誌,我更喜歡+
標誌,雖然功能將與這兩個工作:
A=[-0.1 0];
B=[0.2 -2];
minLenExp = 4;
extsprintf = @(num,fmt,delim) ...
strjoin(cellfun(...
@(toks)[toks{1},repmat('0',1,max([0,minLenExp-length(toks{2})])),toks{2}],...
regexp(sprintf(fmt,num),'([+-\s][\.\d]+[eE][+-])(\d+)','tokens'),...
'UniformOutput',false),delim);
Astr = extsprintf(A,'%+.4E',' ');
Bstr = extsprintf(B,'%+.4E',' ');
disp([Astr;Bstr]);
運行該收益率:
>> foo
-1.0000E-0001 +0.0000E+0000
+2.0000E-0001 -2.0000E+0000
(foo
正是劇本文件名爲)
下面是搜索指數格式,而不是假設它一個更通用的方法。
A=[100 -0.1 0].';
B=[30 0.2 -2];
extsprintf = @(fmt,arr) ...
regexprep(...
sprintf(fmt,arr),...
regexprep(regexp(sprintf(fmt,arr),'([+-\s][\.\d]+[eE][+-]\d+)','match'),'([\+\.])','\\$1'),...
cellfun(@(match)...
cellfun(...
@(toks)[toks{1},repmat('0',1,max([0,minLenExp-length(toks{2})])),toks{2}],...
regexp(match,'([+-\s][\.\d]+[eE][+-])(\d+)','tokens'),...
'UniformOutput',false),...
regexp(sprintf(fmt,arr),'([+-\s][\.\d]+[eE][+-]\d+)','match')));
fmt = '%3d %+.4E %+.4e';
disp(extsprintf(fmt,A));
disp(extsprintf(fmt,B));
輸出
>> foo
100 -1.0000E-0001 +0.0000e+0000
30 +2.0000E-0001 -2.0000e+0000
@BERKO注:我添加的附加信息與您以前版本的一個工作。 – TroyHaskin