Filter löschen
Filter löschen

Excel to timetable, problem with datetime

3 Ansichten (letzte 30 Tage)
OcDrive
OcDrive am 3 Feb. 2024
Bearbeitet: Cris LaPierre am 3 Feb. 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);

Akzeptierte Antwort

Stephen23
Stephen23 am 3 Feb. 2024
Bearbeitet: Stephen23 am 3 Feb. 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 Kommentare
Cris LaPierre
Cris LaPierre am 3 Feb. 2024
Bearbeitet: Cris LaPierre am 3 Feb. 2024
+1 to @Voss for figuring out what the right InputFormat syntax was. The one combination I didn't try!
OcDrive
OcDrive am 3 Feb. 2024
Thanks for all the input, it's been really helpful

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Voss
Voss am 3 Feb. 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

Kategorien

Mehr zu Data Type Conversion 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