Как удалить миллисекунды из отметки времени? - PullRequest
16 голосов
/ 09 марта 2012

Мне задали этот вопрос:

Учитывая длинную метку времени, напишите в Java вспомогательную функцию, чтобы отбрасывать миллисекунды. Например, учитывая вход 1274883865399 (фактическое время: 20100526T14: 24: 25.399Z), функция вернет 1274883865000 (фактическое время: 2010-05-26T14: 24: 25.000Z)

Я сделал это:

import java.text.*;
import java.util.*;

public class ClearMilliSeconds {
    public static void main(String[] args) {   

        long yourmilliseconds = 1274883865399L;
        SimpleDateFormat sdf = new SimpleDateFormat("MMM dd,yyyy HH:mm");
         Calendar c = Calendar.getInstance();


        Date resultdate = new Date(yourmilliseconds);
        c.set(Calendar.MILLISECOND, 0);
        resultdate.setTime(c.getTimeInMillis());
        System.out.println(sdf.format(resultdate)); 
}
}

Но это не дало мне правильный результат

Ответы [ 2 ]

29 голосов
/ 09 марта 2012

Если я вас правильно понимаю, вам не нужно использовать дату / календарь ...

long yourmilliseconds = 1274883865399L;
long droppedMillis = 1000 * (yourmilliseconds/ 1000);    
System.out.println(droppedMillis);

1274883865000

Или ... если вы хотите иметь форматирование даты ...

Calendar c = Calendar.getInstance();
c.setTime(new Date(yourmilliseconds));
c.set(Calendar.MILLISECOND, 0);
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm.ss.SSS'Z'");
sdf.setTimeZone(TimeZone.getTimeZone("GMT"));
System.out.println(sdf.format(c.getTime()));

2010-05-26T14: 24.25.000Z

1 голос
/ 21 июля 2016

У той же проблемы была моя начальная отметка времени, сохраненная в sq и сделал sq.setTime(1000*(long)Math.floor(sq.getTime()/ 1000));, который делает эту работу. В моем случае sq это sql.Timestamp

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...