Excel to timetable, problem with datetime

4 visualizaciones (últimos 30 días)
OcDrive
OcDrive el 3 de Feb. de 2024
Editada: Cris LaPierre el 3 de Feb. de 2024
Hello
The code below doesn't seem to turn my dates into timetable times (it returns NaT). Can anyone see the reason? I'm attaching the data.
Is there an option to get rid of NaN lines and simply leave them empty in the timetable? As a line of space.
Thanks for any assistance.
sheetnames = {'189x', '190x', '191x', '192x', '193x', '194x', '195x', '196x', '197x', '198x', '199x', '200x'};
allTablesCombined = {};
for i = 1:numel(sheetnames)
filename = sheetnames{i};
[~, sheetNames] = xlsfinfo(filename);
% Read each sheet into a cell array of tables
allTables = cell(1, numel(sheetNames));
for j = 1:numel(sheetNames)
currentSheet = sheetNames{j};
allTables{j} = readtable(filename, 'Sheet', currentSheet);
end
% Vertically combine
allTablesCombined = [allTablesCombined, allTables];
end
% Combine all tables into a single table
finalTable = vertcat(allTablesCombined{:});
dateColumn = datetime(finalTable{:, 1}, 'InputFormat', '""dd-MMM-yyyy""');
timeTable = table2timetable(finalTable(:, 2:end), 'RowTimes', dateColumn);

Respuesta aceptada

Stephen23
Stephen23 el 3 de Feb. de 2024
Editada: Stephen23 el 3 de Feb. de 2024
"Can anyone see the reason?"
The date format you are attempting to use does not match the dates given in the file text: there are no double quotes in the date text. It appears that the existing single quotes (which are in the date text) are not liked by DATETIME, so we can trim them before converting.
unzip("Excel Data.zip")
P = "."; % absolute or relative path to where the files are saved.
S = dir(fullfile(P,"*x.xlsx"));
for ii = 1:numel(S)
F = fullfile(P,S(ii).name);
N = sheetnames(F);
C = cell(size(N));
for jj = 1:numel(N)
C{jj} = readtable(F, 'Sheet',N(jj));
end
S(ii).data = vertcat(C{:});
end
T = vertcat(S.data);
T = rmmissing(T)
T = 5806×4 table
Var1 Var2 Var3 Var4 _________________ ____ ____ _____ {''14-Jan-1882''} 2 3 -3001 {''14-Jan-1882''} 2 4 -4401 {''22-Jan-1882''} 2 4 -3102 {''27-Jan-1882''} 2 4 -2502 {''01-Feb-1882''} 2 4 -2402 {''06-Feb-1882''} 2 1 -2596 {''04-Mar-1882''} 2 4 -2701 {''10-Mar-1882''} 2 4 -2401 {''20-Mar-1882''} 2 3 -2501 {''02-Jun-1882''} 2 3 -3002 {''07-Oct-1882''} 2 2 -2401 {''09-Dec-1882''} 2 1 -2802 {''15-Jan-1882''} 4 3 -2500 {''15-Jan-1882''} 4 4 -2499 {''28-Jan-1882''} 4 3 -2498 {''28-Jan-1882''} 4 4 -3198
D = datetime(regexprep(T.Var1,"'",""), "InputFormat","dd-MMM-yyyy");
TT = table2timetable(T(:,2:end), 'RowTimes',D)
TT = 5806×3 timetable
Time Var2 Var3 Var4 ___________ ____ ____ _____ 14-Jan-1882 2 3 -3001 14-Jan-1882 2 4 -4401 22-Jan-1882 2 4 -3102 27-Jan-1882 2 4 -2502 01-Feb-1882 2 4 -2402 06-Feb-1882 2 1 -2596 04-Mar-1882 2 4 -2701 10-Mar-1882 2 4 -2401 20-Mar-1882 2 3 -2501 02-Jun-1882 2 3 -3002 07-Oct-1882 2 2 -2401 09-Dec-1882 2 1 -2802 15-Jan-1882 4 3 -2500 15-Jan-1882 4 4 -2499 28-Jan-1882 4 3 -2498 28-Jan-1882 4 4 -3198
  7 comentarios
Cris LaPierre
Cris LaPierre el 3 de Feb. de 2024
Editada: Cris LaPierre el 3 de Feb. de 2024
+1 to @Voss for figuring out what the right InputFormat syntax was. The one combination I didn't try!
OcDrive
OcDrive el 3 de Feb. de 2024
Thanks for all the input, it's been really helpful

Iniciar sesión para comentar.

Más respuestas (1)

Voss
Voss el 3 de Feb. de 2024
Change the InputFormat to "''dd-MMM-yyyy''" to match what's in the files.
unzip('Excel Data.zip')
sheetnames = {'189x', '190x', '191x', '192x', '193x', '194x', '195x', '196x', '197x', '198x', '199x', '200x'};
allTablesCombined = {};
for i = 1:numel(sheetnames)
filename = sheetnames{i};
[~, sheetNames] = xlsfinfo(filename);
% Read each sheet into a cell array of tables
allTables = cell(1, numel(sheetNames));
for j = 1:numel(sheetNames)
currentSheet = sheetNames{j};
allTables{j} = readtable(filename, 'Sheet', currentSheet);
end
% Vertically combine
allTablesCombined = [allTablesCombined, allTables];
end
% Combine all tables into a single table
finalTable = vertcat(allTablesCombined{:});
% dateColumn = datetime(finalTable{:, 1}, 'InputFormat', '""dd-MMM-yyyy""');
dateColumn = datetime(finalTable{:, 1}, 'InputFormat', "''dd-MMM-yyyy''");
timeTable = table2timetable(finalTable(:, 2:end), 'RowTimes', dateColumn)
timeTable = 6143×3 timetable
Time Var2 Var3 Var4 ___________ ____ ____ _____ 14-Jan-1882 2 3 -3001 14-Jan-1882 2 4 -4401 22-Jan-1882 2 4 -3102 27-Jan-1882 2 4 -2502 01-Feb-1882 2 4 -2402 06-Feb-1882 2 1 -2596 04-Mar-1882 2 4 -2701 10-Mar-1882 2 4 -2401 20-Mar-1882 2 3 -2501 02-Jun-1882 2 3 -3002 07-Oct-1882 2 2 -2401 09-Dec-1882 2 1 -2802 NaT NaN NaN NaN 15-Jan-1882 4 3 -2500 15-Jan-1882 4 4 -2499 28-Jan-1882 4 3 -2498

Categorías

Más información sobre Data Type Conversion en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by