![]() |
在MATLAB中使用textscan()时忽略字符
我正在使用textscan从文件中读取数据。正在读取的数据是:
"ABC",0.156 "DEF",0.125 "GHI",0.101 我的代码是data = textscan(fid, '%s %f', 'Delimiter', ','); 数据{1} '"ABC"' '"DEF"' '"GHI"' 我希望数据{1}为- 'ABC' 'DEF' 'GHI' 最后,我怎样才能得到答案 data = 'ABC' [0.156]; 'DEF' [0.125]; 'GHI' [0.101]; 而不是使用数据{1}和数据{2}。谢谢! [B]回答:[/B] 实际上,有两种方法可以在读取字符串时忽略"字符。根据[URL="http://www.mathworks.com/help/techdoc/ref/textscan.html"]TEXTSCAN[/URL]文档,可以使用%q格式代替%s格式: data = textscan(fid,'%q %f','Delimiter',','); 或者,您可以使用%s格式读取字符串,并使用功能[URL="http://www.mathworks.com/help/techdoc/ref/strrep.html"]STRREP[/URL]从data{1}删除"字符: data{1} = strrep(data{1},'"',''); 然后,您可以使用函数[URL="http://www.mathworks.com/help/techdoc/ref/num2cell.html"]NUM2CELL[/URL]将data{2}的数值数组转换为单元格数组,以便可以[URL="http://www.mathworks.com/help/techdoc/math/f1-84864.html"]将[/URL]其与data{1}的字符串单元格数组[URL="http://www.mathworks.com/help/techdoc/math/f1-84864.html"]连接[/URL]起来: >> data = [data{1} num2cell(data{2})]; data = 'ABC' [0.1560] 'DEF' [0.1250] 'GHI' [0.1010] [url=https://stackoverflow.com/questions/5302578]更多&回答...[/url] |
所有时间均为北京时间。现在的时间是 09:10。 |
Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.