convert excel datetime to time in matlab

조회 수: 137 (최근 30일)
woongki park
woongki park 2018년 9월 30일
댓글: dpb 2018년 10월 1일
in excel file C cell is datetime (2018-09-10 11:24:12 AM)
in matlab i only want to express 11:24:12
so i used a=datestr(xlsread(fileName,'C3:C30000'),'HH:MM:SS' ); but wrong time is shown 2018-09-10 11:50:27 AM -> 12:00:00 (like this)
  댓글 수: 1
Walter Roberson
Walter Roberson 2018년 9월 30일
Please attach a sample file for us to test with.

댓글을 달려면 로그인하십시오.

답변 (2개)

dpb
dpb 2018년 9월 30일
편집: dpb 2018년 9월 30일

Specific file always helps as Walter suggests, but try

 a=datetime(xlsread(fileName,'C3:C30000'),'convertfrom','excel');
 a.Format='HH.mm.ss';

xlsread imports Excel times as Excel time, not Matlab datenum -consistent so must convert to get into correct form for other Matlab functions such as datestr. But, datenum has been superceded by the datetime class so recommend using it instead.

  댓글 수: 2
Walter Roberson
Walter Roberson 2018년 9월 30일
There are multiple representations for times in Excel, with datetime() being appropriate for some of them but not for others.
dpb
dpb 2018년 10월 1일
AFAIK, if they're actual internal dates inside Excel they're either base 1900 or 1904 and will be read as dates by xlsread that way. If they're actually text instead, then xlsread doesn't convert but readtable will if can.
I don't recall ever seeing any other behavior--what do you think is missing here, Walter?

댓글을 달려면 로그인하십시오.


Peter Perkins
Peter Perkins 2018년 10월 1일
If possible, use readtable, not xlsread. It handles many of the vagueries of Excel timestamps, and in recent versionw will automatically convert Excel serial dates (formatted as dates) to datetimes.
At that point, once you have datetimes, you can through away the date portion using the timeofday function. You can make the date portion "disappear" by changing the format (as in dpb's suggestion, but that can be a bit dangerous -- for one thing, two timestamps that look identical may not be.
  댓글 수: 1
dpb
dpb 2018년 10월 1일
But timeofday is a duration, not a time and there can be "issues" in use of it, too, we've spoken of before.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Dates and Time에 대해 자세히 알아보기

태그

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by