Labfans是一个针对大学生、工程师和科研工作者的技术社区。 | 论坛首页 | 联系我们(Contact Us) |
![]() |
![]() |
#1 |
高级会员
注册日期: 2019-11-21
帖子: 3,006
声望力: 66 ![]() |
![]()
我正在使用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}。谢谢! 回答: 实际上,有两种方法可以在读取字符串时忽略"字符。根据TEXTSCAN文档,可以使用%q格式代替%s格式: data = textscan(fid,'%q %f','Delimiter',','); 或者,您可以使用%s格式读取字符串,并使用功能STRREP从data{1}删除"字符: data{1} = strrep(data{1},'"',''); 然后,您可以使用函数NUM2CELL将data{2}的数值数组转换为单元格数组,以便可以将其与data{1}的字符串单元格数组连接起来: >> data = [data{1} num2cell(data{2})]; data = 'ABC' [0.1560] 'DEF' [0.1250] 'GHI' [0.1010] 更多&回答... |
![]() |
![]() |