首页 > 读书能让人学到什么

时间戳转换器?时间戳怎么换算成实际时间

如何实现时间戳转换

以前遇到过一个关于时间戳的问题,为了不被大家鄙视,先说一下概念。

具体时间戳怎么定义的我也不清楚,但百度百科中有这么一句:“时间戳是自 1970年 1月 1日(00:00:00 GMT)至当前时间的总秒数”。

按这个定义,编程语言中倒是有一种类似的函数,getTime(),但这个函数返回的是自1970年1月1日到当前时间的总毫秒数,而不是总秒数。

在js中,将一个字符转化成Date型也不是什么难事:

var str='2013-08-30';//日期字符串

str= str.replace(/-/g,'/');//将-替换成/,因为下面这个构造函数只支持/分隔的日期字符串

var date= new Date(str);//构造一个日期型数据,值为传入的字符串

在上面,new Date(str)构造了一个日期,参数str至少要提供年月日三部分,也就是形如“2013/03/08”的字符串,不能是”2013/03″,否则将得到一个NaN。此时构造出来的时间是:2013/03/08 00:00:00。同时你还可以传入小时、分钟和秒数,但不能只传入小时,比如“2013/03/08 17”,这样的参数同样会得到一个NaN。参数可以是“2013/03/08 17:20”或者“2013/03/08 17:20:05”,这样都可以得到正确的时间,其中如果秒数没给出,则默认为0。

此时得到的是日期型数据,如果要得到上面所谓的时间戳,可以这样:

var time= date.getTime();

这样得到的是一个数值,表示的是从1970年1月1日0点0分0秒到date那一刻的毫秒数,如果把这个数字除以1000,就得到了秒数,同样继续除以60,得到分钟,再除以60得到小时等等。

提示,通过这个getTime()函数,你可以得到两个日期的毫秒数,继而转化成秒数、分钟、小时甚至天数,比较两个日期的差值。

Excel 时间戳和时间格式的互相转换

Excel时间戳和时间格式的互相转换

1、时间戳转换为正常格式:

把B列的格式设置为时间格式。

在B1中输入公式:=(A1+8*3600)/86400+70*365+19,按下enter键

(*秒单位时间戳毫秒单位时间戳记得除以1000)

选中B1,双击左下角的+,即可把一列的时间戳转换为时间格式。

2、正常时间格式转换为时间戳格式:

把C列的格式设置为普通格式(即不用设置)。

把公式变为:=(B1-70*365-19)*86400-8*3600,按下enter键

选中C1,双击左下角的+,即可把一列的时间戳转换为时间格式。

js时间戳怎么转成日期格式

一.js将时间转换成时间戳

1.js获取当前时间戳的方法

var timestamp1= Date.parse(new Date());

var timestamp2=(new Date()).valueOf();

var timestamp3= new Date().getTime();

第一种:获取的时间戳是把毫秒改成000显示,第二种和第三种是获取了当前毫秒的时间戳。

2.js获取制定时间戳的方法

var oldTime=(new Date(“2015/06/23 08:00:20”)).getTime()/1000;

getTime()返回数值的单位是毫秒。

二.js把时间戳转为为普通日期格式

1.Date toLocaleString方法

function getLocalTime(nS){

return new Date(parseInt(nS)* 1000).toLocaleString().replace(/:\d{1,2}$/,'');

}

parseInt()函数可解析一个字符串,并返回一个整数。

js中时间*作单位是毫秒。

toLocaleString()方法可根据本地时间把 Date对象转换为字符串,并返回结果。

replace()方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

replace(/:\d{1,2}$/,'')验证替换以:开始有一位或二位数字的结束字符串,就是秒;替换为空

显示如下:

所以我们可以利用正则表达式改变我们想要的日期格式。

2.Date属性方法

function add0(m){return m<10?'0'+m:m}

function format(shijianchuo)

{

//shijianchuo是整数,否则要parseInt转换

var time= new Date(shijianchuo);

var y= time.getFullYear();

var m= time.getMonth()+1;

var d= time.getDate();

var h= time.getHours();

var mm= time.getMinutes();

var s= time.getSeconds();

return y+'-'+add0(m)+'-'+add0(d)+''+add0(h)+':'+add0(mm)+':'+add0(s);

}

三.封装的时间格式器

/**

*和PHP一样的时间戳格式化函数

*@param{string} format格式

*@param{int} timestamp要格式化的时间默认为当前时间

*@return{string}格式化的时间字符串

*/

function date(format, timestamp){

var a, jsdate=((timestamp)? new Date(timestamp*1000): new Date());

var pad= function(n, c){

if((n= n+””).length< c){

return new Array(++c- n.length).join(“0”)+ n;

} else{

return n;

}

};

var txt_weekdays= [“Sunday”,”Monday”,”Tuesday”,”Wednesday”,”Thursday”,”Friday”,”Saturday”];

var txt_ordin={1:”st”, 2:”nd”, 3:”rd”, 21:”st”, 22:”nd”, 23:”rd”, 31:”st”};

var txt_months= [“”,”January”,”February”,”March”,”April”,”May”,”June”,”July”,”August”,”September”,”October”,”November”,”December”];

var f={

// Day

d: function(){return pad(f.j(), 2)},

D: function(){return f.l().substr(0,3)},

j: function(){return jsdate.getDate()},

l: function(){return txt_weekdays[f.w()]},

N: function(){return f.w()+ 1},

S: function(){return txt_ordin[f.j()]? txt_ordin[f.j()]:'th'},

w: function(){return jsdate.getDay()},

z: function(){return(jsdate- new Date(jsdate.getFullYear()+”/1/1″))/ 864e5>> 0},

// Week

W: function(){

var a= f.z(), b= 364+ f.L()- a;

var nd2, nd=(new Date(jsdate.getFullYear()+”/1/1″).getDay()|| 7)- 1;

if(b<= 2&&((jsdate.getDay()|| 7)- 1)<= 2- b){

return 1;

} else{

if(a<= 2&& nd>= 4&& a>=(6- nd)){

nd2= new Date(jsdate.getFullYear()- 1+”/12/31″);

return date(“W”, Math.round(nd2.getTime()/1000));

} else{

return(1+(nd<= 3?((a+ nd)/ 7):(a-(7- nd))/ 7)>> 0);

}

}

},

// Month

F: function(){return txt_months[f.n()]},

m: function(){return pad(f.n(), 2)},

M: function(){return f.F().substr(0,3)},

n: function(){return jsdate.getMonth()+ 1},

t: function(){

var n;

if((n= jsdate.getMonth()+ 1)== 2){

return 28+ f.L();

} else{

if( n& 1&& n< 8||!(n& 1)&& n> 7){

return 31;

} else{

return 30;

}

}

},

// Year

L: function(){var y= f.Y();return(!(y& 3)&&(y% 1e2||!(y% 4e2)))? 1: 0},

//o not supported yet

Y: function(){return jsdate.getFullYear()},

y: function(){return(jsdate.getFullYear()+””).slice(2)},

// Time

a: function(){return jsdate.getHours()> 11?”pm”:”am”},

A: function(){return f.a().toUpperCase()},

B: function(){

// peter paul koch:

var off=(jsdate.getTimezoneOffset()+ 60)*60;

var theSeconds=(jsdate.getHours()* 3600)+(jsdate.getMinutes()* 60)+ jsdate.getSeconds()+ off;

var beat= Math.floor(theSeconds/86.4);

if(beat> 1000) beat-= 1000;

if(beat< 0) beat+= 1000;

if((String(beat)).length== 1) beat=”00″+beat;

if((String(beat)).length== 2) beat=”0″+beat;

return beat;

},

g: function(){return jsdate.getHours()% 12|| 12},

G: function(){return jsdate.getHours()},

h: function(){return pad(f.g(), 2)},

H: function(){return pad(jsdate.getHours(), 2)},

i: function(){return pad(jsdate.getMinutes(), 2)},

s: function(){return pad(jsdate.getSeconds(), 2)},

//u not supported yet

// Timezone

//e not supported yet

//I not supported yet

O: function(){

var t= pad(Math.abs(jsdate.getTimezoneOffset()/60*100), 4);

if(jsdate.getTimezoneOffset()> 0) t=”-“+ t; else t=”+”+ t;

return t;

},

P: function(){var O= f.O();return(O.substr(0, 3)+”:”+ O.substr(3, 2))},

//T not supported yet

//Z not supported yet

// Full Date/Time

c: function(){return f.Y()+”-“+ f.m()+”-“+ f.d()+”T”+ f.h()+”:”+ f.i()+”:”+ f.s()+ f.P()},

//r not supported yet

U: function(){return Math.round(jsdate.getTime()/1000)}

};

return format.replace(/[\]?([a-zA-Z])/g, function(t, s){

if( t!=s){

// escaped

ret= s;

} else if( f[s]){

// a date function exists

ret= f[s]();

} else{

// nothing special

ret= s;

}

return ret;

});

}

调用方法能够很方便的将时间戳转换成日期的格式,如:

date('Y-m-d','1350052653');//很方便的将时间戳转换成了2012-10-11

date('Y-m-d H:i:s','1350052653');//得到的结果是2012-10-12 22:37:33

本文链接:http://www.kkyx8.com/html/87960676.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件举报,一经查实,本站将立刻删除。