0

我有这个单元格数组:

    date_hour = '30/07/2012 00:00'
                '30/07/2012 01:00'
                '30/07/2012 02:00'
                '30/07/2012 03:00'
                '30/07/2012 04:00'
                '30/07/2012 05:00'
                '30/07/2012 06:00'
                '30/07/2012 07:00'
                '30/07/2012 08:00'
                '30/07/2012 09:00'
                '30/07/2012 10:00'
                '30/07/2012 11:00'
                '30/07/2012 12:00'
                '30/07/2012 13:00'
                '30/07/2012 14:00'
                '30/07/2012 15:00'
                '30/07/2012 16:00'
                '30/07/2012 17:00'
                '30/07/2012 18:00'
                '30/07/2012 19:00'
                '30/07/2012 20:00'
                '30/07/2012 22:00'
                '30/07/2012 21:00'
                '30/07/2012 23:00'

小时以 UTC 给出。一旦当地时间为-3,如何转换为当地时间?

4

2 回答 2

5

由于 matlab 日期格式是自 0000 年 1 月 1 日起的天数,时间为小数,您可以简单地从 matlab 日期格式中减去 3/24。

localDateNum = datenum(date_hour,'dd/mm/yyyy HH:MM') - 3/24;

然后,您可以使用 datestr 将其转换回字符串。

date_hour_local = datestr(localDateNum,'dd/mm/yyyy HH:MM');
于 2012-08-16T14:20:05.873 回答
1

只是为了让您了解另一种解决方案,您可以使用 MATLAB addtodate-function:

date_local_num = addtodate(datenum(date_hour,'dd/mm/yyyy HH:MM'),-3,'hour');
date_local = datestr(date_local_num,'dd/mm/yyyy HH:MM');

有关更多信息,请参阅文档:

http://de.mathworks.com/help/matlab/ref/addtodate.html

于 2016-07-08T10:47:09.853 回答