Plotting multiple text files columns in the same graph
7 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Gabriel Maya
le 6 Mar 2016
Commenté : Gabriel Maya
le 7 Mar 2016
Hi guys, I have about 25 files consisting of 300 rows and 3 columns.
I'd like to plot the first column of each file in the same graph. Is it possible?
Thanks in advance !
3 commentaires
Stephen23
le 7 Mar 2016
@Gabriel Maya: don't use cd to switch between files: this is slow and buggy. It is much more faster and more reliable to pass full/relative filepaths to your file handling functions, exactly as Walter Roberson shows in their answer. Also you should avoid using eval for such trivial code, which is also slow and buggy way to program.
Réponse acceptée
Walter Roberson
le 7 Mar 2016
workDir = 'C:\Users\gabri\Desktop\Nova_pasta\Arquivos_Saida_Imex';
delimiter = '\t';
startRow = 6;
%your description says three columns, your code says four, your previous format implied their might be more
formatSpec = '%f%f%f%f';
for i = 1:25
this_subdir = sprintf('%d', i);
filename = fullfile( workDir, this_subdir, 'arqanepi.rwo');
%%Open the text file.
fileID = fopen(filename, 'rt');
dataArray = textscan(fileID, formatSpec, 'Delimiter', delimiter, 'HeaderLines', startRow-1, 'ReturnOnError', false);
%%Close the text file.
fclose(fileID);
%%Allocate imported array to column variable names
days(:,i) = dataArray{:, 1};
Oil(:,i) = dataArray{:, 2};
Gas(:,i) = dataArray{:, 3};
Water(:,i)= dataArray{:, 4};
end
plot(days(:,1), Oil)
2 commentaires
Ced
le 7 Mar 2016
Did that answer your question? Otherwise, attach one of your files.
PS: If you want to have a legend for all files without having to type it up, you could do something like
N_files = 25;
leg_str = cellfun(@(x)sprintf('dataset %i',x),num2cell(1:N_files),'UniformOutput',0);
legend(leg_str)
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur String Parsing dans Help Center et File Exchange
Produits
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!