How to handle empty strings with datenum
9 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
I have a comma-separated text file I am reading in and parsing using textscan. Two of the fields are the date and time of day. I am able to convert both fields to fractional days using datenum, with the intention to sum the two resulting vectors. The time field is formatted as HHMMSS.SS and the date field as ddmmyy.
My problem is that every so often one of the data messages includes the TIME field but not the DATE field. This is read in by textscan as an empty string. I have found that when datenum encounters the empty string, it returns an empty matrix rather than a NaN value or other filler value. This results in having vectors for TIME and DATE that are not the same length, and no obvious indicator of how to align the data.
How can I handle these empty strings in such a way that preserves the order of the data? Is there a way to get datenum to output a null value rather than simply ignoring the field? I would be fine with having a NaN or 0 or similar value to indicate the empty string. I would prefer to keep this vectorized if possible, but I understand a for loop may be necessary.
I'm using MATLAB 2016a.
2 commentaires
Guillaume
le 3 Jan 2018
Which version of matlab are you using? Is there any reason you're not using readtable and datetime which may make all of this easier?
Can you provide a sample of a file?
Réponse acceptée
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Dates and Time dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!