I have some data files with Unix timestamps (in this case, number of milliseconds since Jan 1, 1970 00:00 UTC). I would like to convert these to human-friendly date/time strings (e.g. 31-Aug-2012 11:36:24) in Matlab. Is there an easy way to do this in Matlab, or am I better off using an external library (e.g. java.text.SimpleDateFormat)?
質問する
47663 次
2 に答える
34
どうですか
date = datestr(unix_time/86400 + datenum(1970,1,1))
unix_time
を秒単位で指定するとunix_time/86400
、1970 年 1 月 1 日からの日数が返されます。これに、Matlab のdatenum
( datenum(0000,1,1) == 1
) で使用されるオフセットを追加すると、0000 年 1 月 1 日からの日数が得られます。これは簡単に人間に変換できます。 -Matlab による可読形式datestr
。
ミリ秒がある場合は、そのまま使用してください
date = datestr(unix_time/86400/1000 + datenum(1970,1,1))
関数にラップすると、これらは次のようになります
function dn = unixtime_to_datenum( unix_time )
dn = unix_time/86400 + 719529; %# == datenum(1970,1,1)
end
function dn = unixtime_in_ms_to_datenum( unix_time_ms )
dn = unix_time_ms/86400000 + 719529; %# == datenum(1970,1,1)
end
datestr( unixtime_to_datenum( unix_time ) )
于 2012-08-31T08:43:35.257 に答える