Reading multiple txt files and placing numerical data in a matrix
5 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Hi all, I'm trying to read multiple file text without the header and pile up their numerical content. I have attached an example txt file.
Here is the basic code I use:
[filename,pathname,d]=uigetfile('*.txt','MultiSelect','on');
filepath=fullpath(pathname,filename);
a=readtable(filepath);
a=table2array(a);
It works for 1 fIle but gives an error for more files selected. And then once I imported correctly multiple files, how do I pile their numerical content? I guess have to insert that in a for cycle. Bear in mind that different files can have different number of columns and rows.
Thanks in advance to anyone who will help me
4 Kommentare
Jan
am 25 Apr. 2022
"but gives an error for more files selected" - whenever you mention an error in the forum, attach a copy of the complete error message instead of letting the readers guess, what you can see already.
Jeremy Hughes
am 25 Apr. 2022
a = readtable(filepath);
a = table2array(a);
Should be equivalent to:
a = readmatrix(filepath)
Antworten (1)
Jan
am 25 Apr. 2022
[filename, pathname] = uigetfile('*.txt','MultiSelect','on');
filename = cellstr(filename);
data = [];
for k = 1:numel(filename)
filepath = fullpath(pathname,filename);
tab = readtable(filepath);
data = cat(1, data, table2array(tab));
end
5 Kommentare
Jan
am 26 Apr. 2022
@lacopo: I've copied "fullpath" from your example in the question. Maybe "fullfile" is meant.
Siehe auch
Kategorien
Mehr zu String Parsing 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!