how to find the index of same datetime value
조회 수: 2 (최근 30일)
이전 댓글 표시
I have two tables of different sizes of datetime
t = 1251x1 datetime
v = 115x1 datetime with the format of YYYY-MM-DD hh:mmm:ss.SSS as attached below.
I'd like to compare datetime (hh:mmm:ss) without considering .SSS and find the index of the same compared values. Can someone help me with this?
댓글 수: 1
Stephen23
2022년 11월 10일
편집: Stephen23
2022년 11월 10일
"I'd like to compare datetime (hh:mmm:ss) without considering .SSS and find the index of the same compared values."
Then use DATESHIFT and ISMEMBER. No loops are required.
DO NOT convert to text and perform text comparisons in complicated nested loops.
채택된 답변
Khushboo
2022년 11월 7일
Hello,
You can use datestr to convert the datetime to a string (it handles the .SSS part). I am not sure if there is any existing function that can compare different rows of different tables to find rows with identical value in a column. So this is what I have done, I ma sure more efficient solutions might exist:
%assuming the two tables are A,B with first column having the datetime value
A.t = datestr(A.t);
B.t = datestr(B.t);
h1 = height(A);
h2 = height(B);
for i = 1:h1
for j = 1:h2
if strcmp(A{i,1},B{j,1}) == 1
i,j
break
end
end
end
Hope this helps!
댓글 수: 4
Lei Hou
2022년 11월 18일
dateset is now in discourage use. You can use [h,m,s] = hms(datetime) to extract time components and then call floor(s) to remove .SSS data.
추가 답변 (1개)
Steven Lord
2022년 11월 7일
Truncate the datetime to the previous whole second then compare.
d = datetime('now');
d.Format = d.Format + ".SSSSSS"
d2 = dateshift(d, 'start', 'second')
d3 = dateshift(d, 'start', 'minute')
댓글 수: 2
Steven Lord
2022년 11월 7일
Let's say I want to check if right now is 6:13 PM (and some number of seconds.) In the example below even though d has those "some number of seconds" d3 trims off those seconds. d is not equal to d4, but d3 is.
d = datetime('now');
d.Format = d.Format + ".SSSSSS"
d2 = dateshift(d, 'start', 'second')
d3 = dateshift(d, 'start', 'minute')
d4 = datetime(2022, 11, 7, 18, 13, 0)
isequal(d4, d3)
isequal(d4, d)
참고 항목
카테고리
Help Center 및 File Exchange에서 Data Type Identification에 대해 자세히 알아보기
제품
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!