How do I convert this string to a date ?
Afficher commentaires plus anciens
Hi everybody !
I'm trying to turn this string to a date (from a txt file): 2021-05-11T14:11:00Z to 'yyyy-MM-dd HH:mm:ss'.
I tried with datetime(ref_time(h, 1),'InputFormat', 'yyyy-MM-dd e HH:mm:ss e','Format','yyyy-MM-dd HH:mm:ss') with an 'e' replacing the 'T' and 'Z' but id doesn't work...
Réponses (2)
Asmit Singh
le 26 Mai 2021
Since you are trying to convert strings to date with literals like 'T' and 'Z', you may want to look at the "Date and Time from Text with Literal Characters" section in the documentation.
The below code converts the given string format to matlab datetime variable.
myDate = "2021-05-11T14:11:10Z"
datetime(myDate,'InputFormat','yyyy-MM-dd''T''HH:mm:ss''Z')
8 commentaires
Allen
le 26 Mai 2021
Asmit,
I just learned that the format for date strings can contain a text representation.
Thanks for sharing that approach.
Jules PASCO
le 26 Mai 2021
Stephen23
le 26 Mai 2021
"The only problem is that I can't turn this format into a datetime, it stays a string."
The string you show in that screenshot does not match the format you described in your question.
Where did that string come from?
Asmit Singh
le 26 Mai 2021
I am not sure how did you reach to this point. But you can still typecast these strings to datetime objects.
datetime("04-May-2021 11:00:00")
Jules PASCO
le 1 Juin 2021
Jules PASCO
le 1 Juin 2021
@Jules PASCO: Of course it will not work: does the "InputFormat" match the input data format? (hint: no)
This is what you are telling MATLAB (and us in your question) that your dates looks like:
'yyyy-MM-dd e HH:mm:ss e'
whereas this is (apparently) what your dates actually look like:
'04-May-2021 11:00:00'
Are they the same format? (hint: no)
"The only problem is that I can't turn this format into a datetime, it stays a string."
It works for me:
S = '04-May-2021 11:00:00';
T = datetime(S, 'InputFormat','dd-MMM-yyyy HH:mm:ss') % !!! DATETIME !!!
T.Format = 'yyyy-MM-dd HH:mm:ss' % !!! Still DATETIME !!!
Did you specify the InputFormat to actually match the data you have?
Jules PASCO
le 2 Juin 2021
Try running a string replacement to remove "T" and "Z" from your string before reformatting to datetime.
str = "2021-05-11T14:11:00Z";
datetime(regexprep(str,["T","Z"],[" ",""]))
1 commentaire
The "T" is specified in ISO 8601, it would be a very unfortunate if DATETIME could not handle it:
The "Z" refers to the Zulu time zone:
and as such it conveys important information which cannot be disregarded:
S = '2021-05-11T14:11:00Z';
T = datetime(S,'InputFormat','yyyy-MM-dd''T''HH:mm:ssZ', 'TimeZone','UTC')
T.TimeZone = 'Asia/Shanghai'
Catégories
En savoir plus sur Dates and Time dans Centre d'aide et File Exchange
Produits
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


