How to take text files and turn the data into variables?

16 Ansichten (letzte 30 Tage)
Vincent Craven
Vincent Craven am 29 Okt. 2015
Bearbeitet: Star Strider am 29 Okt. 2015
When I try to use the automated function produced by the Import Tool it never works. I'm not quite sure what I'm doing wrong but it must be something. For example I am trying to take data in a text file ( organized in order across the top Time Angle Velocity Acceleration) and turn them into variables to be used in Matlab. I'm new to trying this and so any simple explanation could go a long way. Thank You

Akzeptierte Antwort

Star Strider
Star Strider am 29 Okt. 2015
I would have to see your file to provide a definitive reply. My favourite function for text file reading is textscan. It might initially appear a bit complicated to use, but it’s actually straightforward. It has several options because it needs them to work and play well with different text files.
  14 Kommentare
Vincent Craven
Vincent Craven am 29 Okt. 2015
Like, isn't what you put for me to use specific to the LRNR1.txt file. How could I get it to work for 12 documents with different names but the same formats.
Star Strider
Star Strider am 29 Okt. 2015
Bearbeitet: Star Strider am 29 Okt. 2015
The file name would change in the fopen statement each time. You could do that in a for loop. I would use textscan and if all the files have essentially the same filename but differed only in the number, something like this could work:
for k1 = 1:NumFiles
filnam = sprintf('LRNR%d.txt', k1);
fidi = fopen(filnam, 'r');
dc{k1} = textscan(fidi, '%f%f%f%f', 'Delimiter','\t', 'HeaderLines',7);
fclose(fidi);
end
This runs through the list of files, opens each, reads it, saves the data in the ‘dc’ cell array for each iteration of the loop, then closes the file. The data are all saved in ‘dc’.
When you’ve read all of them in, I would save ‘dc’ to a .mat file so you can just load the .mat file rather than having to read in the text files each time. See the documentation on the save function for details.
You can then extract each cell in ‘dc’ to a double array as I did with cell2mat (for example:
d = cell2mat(dc{1});
Time = d(:,1);
Angle = d(:,2);
Velocity = d(:,3)
Acceleration = d(:,4);
and the individual variable assignments to work on for each file.
The first section of code I entered here is UNTESTED but should work.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (3)

Thorsten
Thorsten am 29 Okt. 2015
The data file just contains comma separated values, you can use dlmread. For more complicated data, textscan is fine, as Star Strider recommends. For more specific advice, it please attach the data file.
  6 Kommentare
Thorsten
Thorsten am 29 Okt. 2015
Bearbeitet: Thorsten am 29 Okt. 2015
Do read into four separate variables:
[Time, Angle, Velocity, Accleration] = textread('LRNR1.txt', '%f%f%f%f', 'headerlines', 7);
You can loop over all your files, if they always have 4 columns and 7 headerlines, i.e., are of the same format. Use
d = dir('LNRN*.txt');
for i = 1:numel(d)
[Time(:,i), Angle(:,i), Velocity(:,i), Accleration(:,i)] = textread(d(i).name, '%f%f%f%f', 'headerlines', 7);
end
This works if all the files have the same number of data points. Else use
[Time{i}, Angle{i}, Velocity{i}, Accleration{i}] = ...
Vincent Craven
Vincent Craven am 29 Okt. 2015
How do I make it so that it knows which files to use

Melden Sie sich an, um zu kommentieren.


Vincent Craven
Vincent Craven am 29 Okt. 2015
This is one of the files. I have about 15 that I need to use total. I don't know if it's possible to do all at once or if I need to do them individually. They all for the most part look just like this one.
  1 Kommentar
Vincent Craven
Vincent Craven am 29 Okt. 2015
I clicked on the link and it comes out a little funny but for the most part is fine

Melden Sie sich an, um zu kommentieren.


timo
timo am 29 Okt. 2015
Might i suggest to use python CSV module from inside matlab ? Its stupidly powerfull
  1 Kommentar
Vincent Craven
Vincent Craven am 29 Okt. 2015
No idea what that is or how to use it. If you'd like to teach I'd be up for trying

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Text Data Preparation finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by