How to read a text file and create a structure array?

22 ビュー (過去 30 日間)
Jay
Jay 2013 年 2 月 12 日
Hey,
I have a large data set which is divided into 3 columns and and in two separate text files. I would like to read the data from text files, add the data together so that it is in continuous columns and create a structure from it.
The text files' data is like:
$ABC, 00025, 39.24
. , . , .
. , . , .
I tried this code:
fid = fopen('mydata.txt');
C = textscan(fid, '%s%d8%f32');
fclose(fid);
f = {'Title','Time','Dist'};
s = cell2struct(C,f,2);
but it returns a blank structure array. Can somebody please tell me what is wrong with the code?
Thanks.

採用された回答

ChristianW
ChristianW 2013 年 2 月 13 日
Try to skip the second comma.
C = textscan(fid, '%s%d8%*s%f32');
  2 件のコメント
Jay
Jay 2013 年 2 月 13 日
Thanks, works like a charm.
Now what if I have a second set of similar data which is a continuation of the first. Say mydata2.txt. How do I read this into matlab as well and add it to the first data set to create a single cell array?
ChristianW
ChristianW 2013 年 2 月 14 日
A simple possibility is to load the 2nd file in a 2nd cell and combine them in a for loop.
...
fid = fopen('mydata2.txt');
C2 = textscan(fid,'%s %d8 %f32','delimiter',',');
fclose(fid);
for i = 1:numel(C1)
C{i} = [C1{i}; C2{i}];
end
...

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeData Import and Export についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by