Order CSV based on underlying timestamp OR using correct number

9 visualizaciones (últimos 30 días)
Robin L
Robin L el 16 de Feb. de 2021
Editada: Stephen23 el 18 de Abr. de 2021
We extracted data using LabVIEW and got these kind of files:
For this measurement we have 151 files. But when I try to read them using this code:
%% declare folder containing the files
d = uigetdir(pwd, 'Select a folder');
csvFiles = dir(fullfile(d, '*.csv')); % get all csv files
% csvFilesOrdered = natsortfiles({csvFiles.name});
I tried ordering it through natsortfiles function but this does not work. What we get is:
Is there an easy way to solve this so it reads the files in the correct order? There should be a way to easily extract this but I cannot find it.
Thanks in advance!
  1 comentario
Stephen23
Stephen23 el 17 de Feb. de 2021
Editada: Stephen23 el 18 de Abr. de 2021
"I tried ordering it through natsortfiles function but this does not work."
natsortfiles now directly sorts the output from DIR:
>> S = dir('*.txt');
>> S.name
ans =
'1.txt'
ans =
'10.txt'
ans =
'2.txt'
>> S = natsortfiles(S); % alphanumeric sort by filename
>> S.name
ans =
'1.txt'
ans =
'2.txt'
ans =
'10.txt'

Iniciar sesión para comentar.

Respuesta aceptada

Robin L
Robin L el 17 de Feb. de 2021
Fixed it using:
[r inx]=sort({csvFiles.date});
csvFiles = csvFiles(inx);
  3 comentarios
Robin L
Robin L el 17 de Feb. de 2021
Editada: Robin L el 17 de Feb. de 2021
It gives me the csvFiles 1x151 struct in the correct order like this:
So I think that is enough? I now get the expected results on the graph.
EDIT: I think sorting the way you did would give the same result.
Stephen23
Stephen23 el 17 de Feb. de 2021
Editada: Stephen23 el 17 de Feb. de 2021
"I think sorting the way you did would give the same result."
Not at all.
The way I showed you in my comment sorts the filenames alphanumerically.
Your approach will sort August before February, and the 1st of any month in 2021 before the 2nd of any month in 2020. Have you considered what it really means to sort the character vectors of the date field?
If the dates were given in an ISO 8601 format then your approach would give a robust sort order (by file modification date), but they aren't, so in general the order is not meaningful. Using the datenum field would be robust.

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Shifting and Sorting Matrices en Help Center y File Exchange.

Productos


Versión

R2020b

Community Treasure Hunt

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

Start Hunting!

Translated by