why textscan can't parse the time like this
7 次查看(过去 30 天)
显示 更早的评论
tunit='days since 2024-10-31 18:00:00';
rn=textscan(tunit,'%s since %{yyyy-MM-dd HH:mm:ss}D',1);
0 个评论
采纳的回答
Stephen23
2025-4-8
编辑:Stephen23
2025-4-8
"why textscan can't parse the time like this"
Because you have a delimiter right in the middle of your datestamp. Clearly that will not work: TEXTSCAN always splits at delimiters (because that is the meaning of a delimiter). Also note that you explicitly wrote delimiters in the format string, but with TEXTSCAN you specify the delimiter (or use the default) and then do NOT write it in the format string.
You can parse the date & time as DATETIME & DURATION objects and then add them together:
tunit = 'days since 2024-10-31 18:00:00';
rn = textscan(tunit,'%ssince%{y-M-d}D%{hh:mm:ss}T')
dt = rn{2}+rn{3};
dt.Format = 'yyyy-MM-dd HH:mm:ss'
Or using the automagic DATETIME & DURATION format detection:
rn = textscan(tunit,'%ssince%D%T');
dt = rn{2}+rn{3};
dt.Format = 'yyyy-MM-dd HH:mm:ss'
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Text Files 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!