자바에서 시간 차이 구하기(시간이 24시간으로 받아들여지지 않는 경우) 질문 드립니다.
아라
안녕하세요? 자바에 입문한지 얼마 되지 않은 초짜입니다.
개발 중 잘 되던 것이 갑자기 말썽을 일으켰는데, 혼자 해결이 안되어 질문을 하나 드려봅니다.시간에 관한 건데요, 자바가 24시간으로 받아들이지 못하는 문제가 생겼습니다.
간단하게 말씀드리면 17:00:00를 05:00:00로 받아들인다는 겁니다..제가 한 방식은 이렇습니다.
Time 클래스로 시작 시간과 끝나는 시간을 두 개의 변수를 선언하고, 변수에 저장된 값을
getTime()으로 millisecond로 값을 변경하여 그 값의 차이를 구하였는데, 시간으로 다시 환산하니
시간 차이가 제대로 계산이 안되더군요..
08:00:00 과 17:00:00의 차이를 구하면 17 - 8 = 9 가 나오는 것이 아니라, 5 - 8 = -3이 나옵니다..
어제 낮까지도 제대로 작동하였는데, 저녁 때 jfreechart로 작업을 하다 보니 어느 순간부터
결과가 저렇게 나오더군요. 작업 클래스가 달라 코드를 실수로라도 바꿀 수도 없었는데요..
주변에 물어봐도 다들 이상하다는 반응 뿐이라, 답답한 마음에 이곳에 함 여쭈어 봅니다.
아래는 제가 사용했던 예제 데이터와 해당 코드부분입니다.
고수님들께 한 수 부탁드립니다..[사용 데이터]
Start TimeEnd Time08:00:0014:30:0008:00:0017:00:0008:00:0017:00:0008:00:0017:00:00
[사용 코드]
Time tStartTime = m_LA.getM_productionPlanList().get(0).getM_startTime();
Time tEndTime = m_LA.getM_productionPlanList().get(0).getM_endTime();
// 1. Find Start Time (Start Time = Min (Start Time))
for (int i = 0; i m_LA.getM_productionPlanList().size(); i++)
{
Time tMinStartTime = m_LA.getM_productionPlanList().get(i).getM_startTime();
if (!tStartTime.before(tMinStartTime))
{
tStartTime = tMinStartTime;
}
}// 2. Find End Time (End Time = Max (End Time))
for (int i = 0; i m_LA.getM_productionPlanList().size(); i++)
{
Time tMaxEndTime = m_LA.getM_productionPlanList().get(i).getM_endTime();
if (!tEndTime.after(tMaxEndTime))
{
tEndTime = tMaxEndTime;
 p; }
}
// 3. Get TimeSpan
long lStartTime = tStartTime.getTime() + 60*60*1000*9;// GMT 1970.01.01 09:00시 기준으로 변경 위해 9시간을 더함
long lEndTime = tEndTime.getTime() + 60*60*1000*9;int nStartTime= (int)(lStartTime / (60*60*1000));
int nEndTime = (int)(lEndTime / (60*60*1000));
int nTimeSpan = nEndTime - nStartTime;== 결과 : 5 - 8 = -3
OTL..
-
일진누나
와 ;; POI다~
-
시원
흠.. 내부적으로 어떻게 처리하고 계시는지는 모르겠으나...
엑셀타입이라면...
걍.. 엑셀 라이브러리에 Date 타입으로 해결하시면 될거 같은데--;;
SimpleDateformat등으로 적절히 엑셀 값에 맞는 포멧 형태 지정하신뒤에
POI같은경우 getDateCellValue()를 이용하셔서 처리하시면 될 듯 싶은데...
엑셀처리는 손 뗀지 오래라.. 휘리릭.. -
루라
ㅎㅎ;;;
-
미나
그리고 데이터는 Excel에서 긁어오는데, Cell에는 17:00:00으로 보이더라도 위에 함수 창(?)에는
\1970-01-01 5:00:00 PM\ 또는 \5:00:00 PM\으로 보이는게, 입력되는 형태에 따라 Excel 자체에서 24시제를 AM/PM으로 바꾸어 값을 return하고, 그 값을 자바가 받아들이는 것 같습니다. 뒤에 AM/PM 같은거 안붙이고 함수창에도 순수하게 hh:mm:ss 형태로 넣었더니 방금 읽혔네요. 근데 뒤에 AM/PM -
아연
자바는 Time 클래스에서 getTime() 메소드를 사용하면 GMT 1970년 1월 1일 09:00:00시를 기준으로 시간을 millisecond로 변경합니다. 그래서 08:00:00시 같은 경우는 기준 시간보다 1시간 앞에 있기 때문에 -60*60*1000 = -3600000이라는 값으로 나타납니다.
-
아잉형님
위의 코드를 대략 살표 보니
( tEndTime.getTime() + (60*60*1000*9) ) / ( 60*60*1000) 한 결과가 5라는 말인데,
그렇다면 -_- 저 말은 -_-;
tEndTime.getTime()이 음수가 나온다고 밖에는 볼 수 없겠는데요 -_-?
tEndTime/1시간 + 9시간 = 5시간
tEndTime/1시간 = -4시간
tEndTime = -4시간
-_-;;
우선 tEndTime의 정보 자체가 제대