Program Tip

Unix 타임 스탬프를 JavaScript의 시간으로 변환

programtip 2020. 9. 27. 13:47
반응형

Unix 타임 스탬프를 JavaScript의 시간으로 변환


MySQL 데이터베이스에 Unix 타임 스탬프로 시간을 저장하고 있으며 일부 JavaScript 코드로 전송됩니다. 시간을 어떻게 얻을 수 있습니까?

예를 들어 HH / MM / SS 형식입니다.


// Create a new JavaScript Date object based on the timestamp
// multiplied by 1000 so that the argument is in milliseconds, not seconds.
var date = new Date(unix_timestamp*1000);
// Hours part from the timestamp
var hours = date.getHours();
// Minutes part from the timestamp
var minutes = "0" + date.getMinutes();
// Seconds part from the timestamp
var seconds = "0" + date.getSeconds();

// Will display time in 10:30:23 format
var formattedTime = hours + ':' + minutes.substr(-2) + ':' + seconds.substr(-2);

Date 객체에 대한 자세한 내용은 MDN 또는 ECMAScript 5 사양을 참조하십시오 .


function timeConverter(UNIX_timestamp){
  var a = new Date(UNIX_timestamp * 1000);
  var months = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
  var year = a.getFullYear();
  var month = months[a.getMonth()];
  var date = a.getDate();
  var hour = a.getHours();
  var min = a.getMinutes();
  var sec = a.getSeconds();
  var time = date + ' ' + month + ' ' + year + ' ' + hour + ':' + min + ':' + sec ;
  return time;
}
console.log(timeConverter(0));


JavaScript는 밀리 초 단위로 작동하므로 먼저 UNIX 타임 스탬프를 초에서 밀리 초로 변환해야합니다.

var date = new Date(UNIX_Timestamp * 1000);
// Manipulate JavaScript Date object here...

저는 Date.format()PHP date()함수 스타일로 JavaScript 날짜 형식을 구현 하는 Jacob Wright의 라이브러리에 부분적 입니다.

new Date(unix_timestamp * 1000).format('h:i:s')

다음은 초 형식을 다음과 같이 지정하는 가장 짧은 한 줄짜리 솔루션입니다 hh:mm:ss.

/**
 * Convert seconds to time string (hh:mm:ss).
 *
 * @param Number s
 *
 * @return String
 */
function time(s) {
    return new Date(s * 1e3).toISOString().slice(-13, -5);
}

console.log( time(12345) );  // "03:25:45"

메서드 항상 24 자 또는 27 자 (즉 , 각각) 인 Date.prototype.toISOString()단순화 된 확장 ISO 8601 형식으로 시간을 반환합니다 . 시간대는 항상 0 UTC 오프셋입니다.YYYY-MM-DDTHH:mm:ss.sssZ±YYYYYY-MM-DDTHH:mm:ss.sssZ

주의 :이 솔루션은 타사 라이브러리가 필요하지 않으며 모든 최신 브라우저 및 JavaScript 엔진에서 지원됩니다.


사용하다:

var s = new Date(1504095567183).toLocaleDateString("en-US")
// expected output "8/30/2017"   

그리고 시간 :

var s = new Date(1504095567183).toLocaleTimeString("en-US") 
// expected output "3:19:27 PM"`

Date.prototype.toLocaleDateString () 참조


나는 momentjs.com 과 같은 라이브러리를 사용하는 것에 대해 생각할 것입니다 .

Unix 타임 스탬프를 기반으로 :

var timestamp = moment.unix(1293683278);
console.log( timestamp.format("HH/mm/ss") );

MySQL 날짜 문자열을 기반으로 :

var now = moment("2010-10-10 12:03:15");
console.log( now.format("HH/mm/ss") );

UNIX 타임 스탬프는 1970 년 1 월 1 일 00:00:00 UTC 이후 수입니다 ( Wikipedia 에 따름 ).

Javascript에서 Date 객체의 인수는 1970 년 1 월 1 일 00:00:00 UTC 이후 밀리 초입니다 ( W3Schools Javascript 문서 에 따름 ).

예를 들어 아래 코드를 참조하십시오.

    function tm(unix_tm) {
        var dt = new Date(unix_tm*1000);
        document.writeln(dt.getHours() + '/' + dt.getMinutes() + '/' + dt.getSeconds() + ' -- ' + dt + '<br>');

    }

tm(60);
tm(86400);

제공합니다 :

1/1/0 -- Thu Jan 01 1970 01:01:00 GMT+0100 (Central European Standard Time)
1/0/0 -- Fri Jan 02 1970 01:00:00 GMT+0100 (Central European Standard Time)

Moment.js를 사용하면 다음 과 같이 시간과 날짜를 얻을 수 있습니다.

var dateTimeString = moment(1439198499).format("DD-MM-YYYY HH:mm:ss");

그리고 이것을 사용하여 시간을 얻을 수 있습니다.

var timeString = moment(1439198499).format("HH:mm:ss");

앞서 언급 한 솔루션의 문제점은 시간, 분 또는 초에 한 자리 (예 : 0-9) 만 있으면 시간이 잘못 될 수 있다는 것입니다. 예를 들어 2 : 3 : 9 일 수 있지만 오히려 02 여야합니다. 03:09.

이 페이지 에 따르면 Date의 "toLocaleTimeString"메소드를 사용하는 것이 더 나은 솔루션 인 것 같습니다.


또 다른 방법 -ISO 8601 날짜에서.

var timestamp = 1293683278;
var date = new Date(timestamp*1000);
var iso = date.toISOString().match(/(\d{2}:\d{2}:\d{2})/)
alert(iso[1]);

순간 유닉스 타임 스탬프를 사용해야합니다.

var dateTimeString = moment.unix(1466760005).format("DD-MM-YYYY HH:mm:ss");

초 형식을 hh : mm : ss : 변형으로 지정하는 가장 짧은 한 줄짜리 솔루션 :

console.log(new Date(1549312452 * 1000).toISOString().slice(0, 19).replace('T', ' '));
// "2019-02-04 20:34:12"


40KB 라이브러리가 필요하지 않은 최신 솔루션 :

Intl.DateTimeFormat 은 날짜 / 시간을 형식화하는 비문화적으로 제국주의적인 방법입니다.

// Setup once
var options = {
    //weekday: 'long',
    //month: 'short',
    //year: 'numeric',
    //day: 'numeric',
    hour: 'numeric',
    minute: 'numeric',
    second: 'numeric'
},
intlDate = new Intl.DateTimeFormat( undefined, options );

// Reusable formatter
var timeStamp = 1412743273;
console.log( intlDate.format( new Date( 1000 * timeStamp ) ) );

@shomrat의 답변에 따라 다음과 같이 datetime을 자동으로 작성하는 스 니펫이 있습니다 (답변에 대한 StackOverflow의 날짜와 약간 유사 answered Nov 6 '16 at 11:51).

today, 11:23

또는

yersterday, 11:23

또는 (오늘과 다르지만 같은 해인 경우)

6 Nov, 11:23

또는 (오늘과 다른 1 년이 지난 경우)

6 Nov 2016, 11:23

function timeConverter(t) {     
    var a = new Date(t * 1000);
    var today = new Date();
    var yesterday = new Date(Date.now() - 86400000);
    var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
    var year = a.getFullYear();
    var month = months[a.getMonth()];
    var date = a.getDate();
    var hour = a.getHours();
    var min = a.getMinutes();
    if (a.setHours(0,0,0,0) == today.setHours(0,0,0,0))
        return 'today, ' + hour + ':' + min;
    else if (a.setHours(0,0,0,0) == yesterday.setHours(0,0,0,0))
        return 'yesterday, ' + hour + ':' + min;
    else if (year == today.getFullYear())
        return date + ' ' + month + ', ' + hour + ':' + min;
    else
        return date + ' ' + month + ' ' + year + ', ' + hour + ':' + min;
}

function getTIMESTAMP() {
      var date = new Date();
      var year = date.getFullYear();
      var month = ("0"+(date.getMonth()+1)).substr(-2);
      var day = ("0"+date.getDate()).substr(-2);
      var hour = ("0"+date.getHours()).substr(-2);
      var minutes = ("0"+date.getMinutes()).substr(-2);
      var seconds = ("0"+date.getSeconds()).substr(-2);

      return year+"-"+month+"-"+day+" "+hour+":"+minutes+":"+seconds;
    }
//2016-01-14 02:40:01

내 타임 스탬프가 PHP 백엔드에서 가져오고 있습니다. 위의 모든 방법을 시도했지만 작동하지 않았습니다. 그런 다음 작동하는 자습서를 보았습니다.

var d =val.timestamp;
var date=new Date(+d); //NB: use + before variable name

console.log(d);
console.log(date.toDateString());
console.log(date.getFullYear());
console.log(date.getMinutes());
console.log(date.getSeconds());
console.log(date.getHours());
console.log(date.toLocaleTimeString());

위의 방법은이 결과를 생성합니다

1541415288860
Mon Nov 05 2018 
2018 
54 
48 
13
1:54:48 PM

타임 스탬프와 완벽하게 작동하는 방법이 많이 있습니다. 모두 나열 할 수 없습니다.


Pay attention to the zero problem with some of the answers. For example, the timestamp 1439329773 would be mistakenly converted to 12/08/2015 0:49.

I would suggest on using the following to overcome this issue:

var timestamp = 1439329773; // replace your timestamp
var date = new Date(timestamp * 1000);
var formattedDate = ('0' + date.getDate()).slice(-2) + '/' + ('0' + (date.getMonth() + 1)).slice(-2) + '/' + date.getFullYear() + ' ' + ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2);
console.log(formattedDate);

Now results in:

12/08/2015 00:49

// Format value as two digits 0 => 00, 1 => 01
function twoDigits(value) {
   if(value < 10) {
    return '0' + value;
   }
   return value;
}

var date = new Date(unix_timestamp*1000);
// display in format HH:MM:SS
var formattedTime = twoDigits(date.getHours()) 
      + ':' + twoDigits(date.getMinutes()) 
      + ':' + twoDigits(date.getSeconds());

See Date/Epoch Converter.

You need to ParseInt, otherwise it wouldn't work:


if (!window.a)
    window.a = new Date();

var mEpoch = parseInt(UNIX_timestamp);

if (mEpoch < 10000000000)
    mEpoch *= 1000;

------
a.setTime(mEpoch);
var year = a.getFullYear();
...
return time;

You can use the following function to convert your timestamp to HH:MM:SS format :

var convertTime = function(timestamp, separator) {
    var pad = function(input) {return input < 10 ? "0" + input : input;};
    var date = timestamp ? new Date(timestamp * 1000) : new Date();
    return [
        pad(date.getHours()),
        pad(date.getMinutes()),
        pad(date.getSeconds())
    ].join(typeof separator !== 'undefined' ?  separator : ':' );
}

Without passing a separator, it uses : as the (default) separator :

time = convertTime(1061351153); // --> OUTPUT = 05:45:53

If you want to use / as a separator, just pass it as the second parameter:

time = convertTime(920535115, '/'); // --> OUTPUT = 09/11/55

Demo

var convertTime = function(timestamp, separator) {
    var pad = function(input) {return input < 10 ? "0" + input : input;};
    var date = timestamp ? new Date(timestamp * 1000) : new Date();
    return [
        pad(date.getHours()),
        pad(date.getMinutes()),
        pad(date.getSeconds())
    ].join(typeof separator !== 'undefined' ?  separator : ':' );
}

document.body.innerHTML = '<pre>' + JSON.stringify({
    920535115 : convertTime(920535115, '/'),
    1061351153 : convertTime(1061351153, ':'),
    1435651350 : convertTime(1435651350, '-'),
    1487938926 : convertTime(1487938926),
    1555135551 : convertTime(1555135551, '.')
}, null, '\t') +  '</pre>';

See also this Fiddle.


function timeConverter(UNIX_timestamp){
 var a = new Date(UNIX_timestamp*1000);
     var hour = a.getUTCHours();
     var min = a.getUTCMinutes();
     var sec = a.getUTCSeconds();
     var time = hour+':'+min+':'+sec ;
     return time;
 }

If you want to convert Unix time duration to real hours, minutes, and seconds, you could use the following code:

var hours = Math.floor(timestamp / 60 / 60);
var minutes = Math.floor((timestamp - hours * 60 * 60) / 60);
var seconds = Math.floor(timestamp - hours * 60 * 60 - minutes * 60 );
var duration = hours + ':' + minutes + ':' + seconds;

 function getDateTimeFromTimestamp(unixTimeStamp) {
    var date = new Date(unixTimeStamp);
    return ('0' + date.getDate()).slice(-2) + '/' + ('0' + (date.getMonth() + 1)).slice(-2) + '/' + date.getFullYear() + ' ' + ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2);
  }

var myTime = getDateTimeFromTimestamp(1435986900000);
console.log(myTime); // output 01/05/2000 11:00

function getDateTime(unixTimeStamp) {

    var d = new Date(unixTimeStamp);
    var h = (d.getHours().toString().length == 1) ? ('0' + d.getHours()) : d.getHours();
    var m = (d.getMinutes().toString().length == 1) ? ('0' + d.getMinutes()) : d.getMinutes();
    var s = (d.getSeconds().toString().length == 1) ? ('0' + d.getSeconds()) : d.getSeconds();

    var time = h + '/' + m + '/' + s;

    return time;
}

var myTime = getDateTime(1435986900000);
console.log(myTime); // output 01/15/00

Code below also provides 3-digit millisecs, ideal for console log prefixes:

const timeStrGet = date => {
    const milliSecsStr = date.getMilliseconds().toString().padStart(3, '0') ;
    return `${date.toLocaleTimeString('it-US')}.${milliSecsStr}`;
};

setInterval(() => console.log(timeStrGet(new Date())), 299);

참고URL : https://stackoverflow.com/questions/847185/convert-a-unix-timestamp-to-time-in-javascript

반응형