FavoriteLoading
0

时间戳如何转换为日期格式?MySQL、C#、JS时间戳转换方法

时间戳如何转换为日期格式?当初把日期格式转换为时间戳是为了更好的记录数据,现在如果想要看看当初时间戳被转换的时间,可以按照以下方法来实现,详情请阅读下文MySQL、C#、JS时间戳转换方法。

时间戳如何转换为日期格式?MySQL、C#、JS时间戳转换方法

MySQL、C#、JS时间戳转换方法:

一、MySQL戳转换方法:

1、原理:

时间戳的原理是把时间格式转为十进制格式,这样就方便时间的计算,如:1377216000000 转化后是 2013年08月23日 。

1、步骤:

(1) 创建 DateUtilsl类。

(2) 输入代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
importjava.text.ParseException;
importjava.text.SimpleDateFormat;
importjava.util.Date;  
/*
* @author Msquirrel
*/

public class DateUtils {  
privateSimpleDateFormat sf = null;
/*获取系统时间 格式为:"yyyy/MM/dd "*/
public static String getCurrentDate() {
Date d = newDate();
sf = newSimpleDateFormat("yyyy年MM月dd日");
returnsf.format(d);
}  
/*时间戳转换成字符窜*/
public static String getDateToString(long time) {
Date d = newDate(time);
sf = newSimpleDateFormat("yyyy年MM月dd日");
returnsf.format(d);
}  
/*将字符串转为时间戳*/
public static long getStringToDate(String time) {
sdf = newSimpleDateFormat("yyyy年MM月dd日");
Date date = newDate();
try{
date = sdf.parse(time);
} catch(ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
returndate.getTime();
}

2、在对应使用的地方调用。

代码如下:

1
2
3
DateUtils.getCurrentDate(); //获取系统当前时间  
DateUtils.getDateToString(时间戳); //时间戳转为时间格式  
DateUtils.getStringToDate("时间格式");//时间格式转为时间戳.

  二、C#时间戳转换方法:

  C#的代码(加入了闰年):

  注:.Net的DateTime对象返回的是100纳秒的时间单位,年份是从AD1开始计算的。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
class Program
{
// 定义必须变量
const int _1M = 60; // 分钟
const int _1H = _1M * 60; // 小时
const int _1D = _1H * 24; // 天
const long _1Y = _1D * 365; // 年(非闰年)
const long _YS = _1Y * 3 + _1D * 366; // 一个闰年年度
const long _30D = _1D * 30; // 30天(月)
const long _31D = _1D * 31; // 31天(月)
const long _28D = _1D * 28; // 28天(月)
const long _29D = _1D * 29; // 29天(月)
long[] NormalYear = { _31D, _28D, _31D, _30D, _31D, _30D, _31D, _31D, _30D, _31D, _30D, _31D }; // 年
long[] LeapYear = { _31D, _29D, _31D, _30D, _31D, _30D, _31D, _31D, _30D, _31D, _30D, _31D }; // 闰年
static void Main(string[] args)
{
Program P = new Program();
System.Console.WriteLine(P.getDate(P.getTimeSpame()));
DateTime T = DateTime.Now;
System.Console.WriteLine(P.getTimeSpame() + " : " + P.getTimeSpame(T.Year, T.Month, T.Day, T.Hour, T.Minute, T.Second));
System.Console.ReadKey();
}
private Program() {}
public string getDate(long TimeSp)
{
// 年,月,天,小时,分钟,秒
int year = 0;
int month = 0;
int day = 0;
int hour = 0;
int minute = 0;
int second = 0;
//DateTime now = DateTime.Now;
//long TimeSp = getTimeSpame(); // 当前时间戳
// 年
int _y1 = (int)(TimeSp / _YS); // 获得按年度得到的年度
TimeSp -= _YS * _y1; // 计算剩余秒
int _y2 = (int)(TimeSp / _1Y); // 剩余年
TimeSp -= _1Y * _y2;
year = _y1 * 4 + _y2 + 1970;
// 月
long[] YearArr = isLeapYear(year) ? LeapYear : NormalYear; // 获取年的月度表
month = 1; // 从1月开始计算
for (int i = 0; i < YearArr.Length; i++)
{
if (TimeSp - YearArr[i] < 0) break;
++month;
TimeSp -= YearArr[i];
}
// 天
day = (int)(TimeSp / _1D);
TimeSp -= day * _1D;
// 时
hour = (int)(TimeSp / _1H);
TimeSp -= hour * _1H;
// 分
minute = (int)(TimeSp / _1M);
// 秒
second = (int)(TimeSp % _1M);
string DateStr = year + "年" + month + "月" + day + "日 " + hour + "点" + minute + "分" + second + "秒";
return DateStr;
}
// 判断是否闰年
private bool isLeapYear(int year)
{
return (year % 4 == 0 ? true : false);
}
// 获取当前时间戳 按1970年开始计算,精度为秒!
private long getTimeSpame()
{
DateTime _Now = DateTime.Now;
DateTime _1970 = new DateTime(1970, 1, 1);
long _Sp = (_Now.Ticks - _1970.Ticks) / 10000000;
return _Sp;
}
// 按既定格式把时间转成成时间戳
private long getTimeSpame(int Year, int Month, int Day, int Hour, int Minute, int Second)
{
long val = 0;
val += Second; // 秒
val += Minute * _1M; // 分钟
val += Hour * _1H; // 小时
val += Day * _1D; // 天
long[] YearArr = isLeapYear(Year) ? LeapYear : NormalYear;
for (int i = 0; i < Month - 1; i++)
{
val += YearArr[i];
}
Year -= 1970;
val += (Year / 4) * _YS;
Year -= (int)(Year / 4) * 4;
val += Year * _1Y;
return val;
}
}

三、JS时间戳转换方法:

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// 定义常量
var _1M = 60; // 分钟
var _1H = _1M * 60; // 小时
var _1D = _1H * 24; // 天
var _1Y = _1D * 365; // 年(非闰年)
var _YS = _1Y * 3 + _1D * 366; // 一个闰年年度
var _30D = _1D * 30; // 30天(月)
var _31D = _1D * 31; // 31天(月)
var _28D = _1D * 28; // 28天(月)
var _29D = _1D * 29; // 29天(月)
var NormalYear = [ _31D, _28D, _31D, _30D, _31D, _30D, _31D, _31D, _30D, _31D, _30D, _31D ]; // 年
var LeapYear = [ _31D, _29D, _31D, _30D, _31D, _30D, _31D, _31D, _30D, _31D, _30D, _31D ]; // 闰年
var Now = new Date();
TimeSp = Now.getTime() / 1000;
//alert(Now.getTimezoneOffset()); // 时区差
TimeSp += -1 * Now.getTimezoneOffset() * _1M; // 修正UTC
// 年,月,天,小时,分钟,秒
var year = month = day = hour = minute = second = 0;
// 年
var _y1 = parseInt(TimeSp / _YS); // 获得按年度得到的年度
TimeSp -= _YS * _y1; // 计算剩余秒
var _y2 = parseInt(TimeSp / _1Y); // 剩余年
TimeSp -= _1Y * _y2;
year = _y1 * 4 + _y2 + 1970;
// 月
var YearArr = year % 4 == 0 ? LeapYear : NormalYear; // 获取年的月度表
month = 1; // 从1月开始计算
for (i=0; i<YearArr.length; i++)
{
if (TimeSp - YearArr[i] < 0) break;
++month;
TimeSp -= YearArr[i];
}
// 天
day = parseInt(TimeSp / _1D);
TimeSp -= day * _1D;
// 时
hour = parseInt(TimeSp / _1H);
TimeSp -= hour * _1H;
// 分
minute = parseInt(TimeSp / _1M);
// 秒
second = parseInt(TimeSp % _1M);
var DateStr = year + "年" + month + "月" + day + "日 " + hour + "点" + minute + "分" + second + "秒";
alert(DateStr);

注:JS的Date对象的getTime()方法返回的是UTC的时间戳,可以使用getTimezoneOffset()的方法来返回与UTC时差的分钟。

以上代码便是MySQL、C#、JS的时间戳转换方法介绍,因为闰年的存在,代码的使用前请阅读一下。