MySQL 데이터베이스에 유닉스 타임 스탬프로 시간을 저장하고 있으며 JavaScript 코드로 전송됩니다. 시간을 어떻게 빼낼 수 있을까요?
예를 들어, HH / MM / SS 형식입니다.
MySQL 데이터베이스에 유닉스 타임 스탬프로 시간을 저장하고 있으며 JavaScript 코드로 전송됩니다. 시간을 어떻게 빼낼 수 있을까요?
예를 들어, HH / MM / SS 형식입니다.
답변:
let unix_timestamp = 1549312452
// 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);
console.log(formattedTime);
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));
var min = a.getMinutes() < 10 ? '0' + a.getMinutes() : a.getMinutes(); var sec = a.getSeconds() < 10 ? '0' + a.getSeconds() : a.getSeconds();
getMonth()
0에서 11 사이의 월 숫자를 반환하므로 a.getMonth() - 1
잘못되었습니다.
Date.format()
PHP date()
기능 스타일로 JavaScript 날짜 형식을 구현 하는 Jacob Wright 라이브러리 의 일부 입니다.
new Date(unix_timestamp * 1000).format('h:i:s')
format is not a function
. 그러나 이것은 분명히 작동합니다 : stackoverflow.com/a/34015511/7550772
사용하다:
var s = new Date(1504095567183).toLocaleDateString("en-US")
console.log(s)
// expected output "8/30/2017"
그리고 시간 :
var s = new Date(1504095567183).toLocaleTimeString("en-US")
console.log(s)
// expected output "3:19:27 PM"
toLocaleString
날짜와 시간을 모두 포함합니다.
다음은 초를 형식화하는 가장 짧은 단일 라이너 솔루션입니다 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"
메소드
Date.prototype.toISOString()
는 단순화 된 확장 ISO 8601 형식으로 시간을 반환하며 , 항상 24 자 또는 27 자 (즉YYYY-MM-DDTHH:mm:ss.sssZ
,±YYYYYY-MM-DDTHH:mm:ss.sssZ
각각)입니다. 시간대는 항상 0 UTC 오프셋입니다.
NB :이 솔루션에는 타사 라이브러리가 필요하지 않으며 모든 최신 브라우저 및 JavaScript 엔진에서 지원됩니다.
toTimeString
시간대와 잘 작동하지 않았습니다. 불행히도 편집하기 전에 거부되었습니다. 그러나 더 이상 사용되지 않으며 다른 플랫폼에서 다른 결과를 반환 할 수 toISOString
있으므로 대신 사용 하는 것이 좋습니다 toGMTString
.
momentjs.com 과 같은 라이브러리를 사용하여 이것을 간단하게 만들 수 있습니다.
유닉스 타임 스탬프를 기반으로 :
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") );
console.log
예에서로 인해 형식에 대해 혼란 스러웠지만 /
많은 도움이되었습니다.
UNIX 타임 스탬프는 1970 년 1 월 1 일 00:00:00 UTC 이후 의 초 수입니다 ( Wikipedia 에 따름) ).
Javascript에서 Date 객체의 인수는 1970 년 1 월 1 일 UTC 00:00:00 이후 ( 밀리 초)입니다 ( 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)
초를 hh : mm : ss : 형식으로 지정하는 가장 짧은 단일 라이너 솔루션 :
console.log(new Date(1549312452 * 1000).toISOString().slice(0, 19).replace('T', ' '));
// "2019-02-04 20:34:12"
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"메소드를 사용하는 것이 더 나은 솔루션 인 것 같습니다.
date.toLocaleTimeString()
toTimeString
방법으로 는 발생하지 않습니다 . 여기를 확인하십시오 : stackoverflow.com/a/35890537/1249581 .
다른 방법은 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]);
@ shomrat의 답변을 바탕으로 다음과 같이 날짜 시간을 자동으로 쓰는 스 니펫이 있습니다 (스택에 대한 StackOverflow의 날짜와 약간 비슷합니다 :) answered Nov 6 '16 at 11:51
.
today, 11:23
또는
yersterday, 11:23
또는 (오늘과 다르지만 같은 해)
6 Nov, 11:23
또는 (오늘날과 다른 연도 인 경우)
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;
}
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 ) ) );
내 타임 스탬프가 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
타임 스탬프와 완벽하게 작동하는 여러 가지 방법이 있습니다. 캔트 그들 모두를 나열
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
일부 답변에서 제로 문제에주의하십시오. 예를 들어 타임 스탬프 1439329773
는 실수로12/08/2015 0:49
.
이 문제를 극복하기 위해 다음을 사용하는 것이 좋습니다.
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);
이제 결과는 다음과 같습니다.
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());
날짜 / 시간 변환기를 참조하십시오 .
당신은 필요 ParseInt
그렇지 않으면 작동하지 않을 것입니다 :
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;
다음 함수를 사용하여 타임 스탬프를 HH:MM:SS
형식으로 변환 할 수 있습니다 .
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 : ':' );
}
구분 기호를 전달하지 않고 :
(기본) 구분 기호로 사용합니다.
time = convertTime(1061351153); // --> OUTPUT = 05:45:53
/
구분자 로 사용 하려면 두 번째 매개 변수로 전달하십시오.
time = convertTime(920535115, '/'); // --> OUTPUT = 09/11/55
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>';
이 바이올린을 참조하십시오 .
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
js에서 타임 스탬프를 날짜 문자열로 변환
moment().format('YYYY-MM-DD hh:mm:ss');
// "2020-01-10 11:55:43"
moment(1578478211000).format('YYYY-MM-DD hh:mm:ss');
// "2020-01-08 06:10:11"
day.js
github.com/iamkun/dayjs
@ Aron의 대답은 효과가 있지만 1980 년부터 타임 스탬프를 변환하려고 시도했을 때 효과가 없었습니다. 따라서 다음과 같이 약간 변경했습니다.
function ConvertUnixTimeToDateForLeap(UNIX_Timestamp) {
var dateObj = new Date(1980, 0, 1, 0, 0, 0, 0);
dateObj.setSeconds(dateObj.getSeconds() + UNIX_Timestamp);
return dateObj;
}
document.body.innerHTML = 'TimeStamp : ' + ConvertUnixTimeToDateForLeap(1269700200);
다른 10 년 정도의 타임 스탬프가 있다면 이것을 사용하십시오. 그것은 나를 위해 많은 두통을 구했습니다.