-
时间戳如何转换为日期格式?MySQL、C#、JS时间戳转换方法
- 时间:2024-11-23 16:25:51
大家好,今天Win10系统之家小编给大家分享「时间戳如何转换为日期格式?MySQL、C#、JS时间戳转换方法」的知识,如果能碰巧解决你现在面临的问题,记得收藏本站或分享给你的好友们哟~,现在开始吧!
时间戳如何转换为日期格式?当初把日期格式转换为时间戳是为了更好的记录数据,现在如果想要看看当初时间戳被转换的时间,可以按照以下方法来实现,详情请阅读下文MySQL、C#、JS时间戳转换方法。
MySQL、C#、JS时间戳转换方法:
一、MySQL戳转换方法:
1、原理:
时间戳的原理是把时间格式转为十进制格式,这样就方便时间的计算,如:1377216000000 转化后是 2013年08月23日 。
2、步骤:
(1) 创建 DateUtilsl类。
(2) 输入代码:
- 01importjava.text.ParseException;
- 02importjava.text.SimpleDateFormat;
- 03importjava.util.Date;
- 04/*
- 05* @author Msquirrel
- 06*/
- 07public class DateUtils {
- 08privateSimpleDateFormat sf = null;
- 09/*获取系统时间 格式为:"yyyy/MM/dd "*/
- 10public static String getCurrentDate() {
- 11Date d = newDate();
- 12sf = newSimpleDateFormat("yyyy年MM月dd日");
- 13returnsf.format(d);
- 14}
- 15/*时间戳转换成字符窜*/
- 16public static String getDateToString(long time) {
- 17Date d = newDate(time);
- 18sf = newSimpleDateFormat("yyyy年MM月dd日");
- 19returnsf.format(d);
- 20}
- 21/*将字符串转为时间戳*/
- 22public static long getStringToDate(String time) {
- 23sdf = newSimpleDateFormat("yyyy年MM月dd日");
- 24Date date = newDate();
- 25try{
- 26date = sdf.parse(time);
- 27} catch(ParseException e) {
- 28// TODO Auto-generated catch block
- 29e.printStackTrace();
- 30}
- 31returndate.getTime();
- 32}
3、在对应使用的地方调用:
- 01DateUtils.getCurrentDate(); //获取系统当前时间
- 02DateUtils.getDateToString(时间戳); //时间戳转为时间格式
- 03DateUtils.getStringToDate("时间格式");//时间格式转为时间戳.
二、C#时间戳转换方法:
C#的代码(加入了闰年):
注:.Net的DateTime对象返回的是100纳秒的时间单位,年份是从AD1开始计算的。
- 01class Program
- 02{
- 03// 定义必须变量
- 04const int _1M = 60; // 分钟
- 05const int _1H = _1M * 60; // 小时
- 06const int _1D = _1H * 24; // 天
- 07const long _1Y = _1D * 365; // 年(非闰年)
- 08const long _YS = _1Y * 3 + _1D * 366; // 一个闰年年度
- 09const long _30D = _1D * 30; // 30天(月)
- 10const long _31D = _1D * 31; // 31天(月)
- 11const long _28D = _1D * 28; // 28天(月)
- 12const long _29D = _1D * 29; // 29天(月)
- 13long[] NormalYear = { _31D, _28D, _31D, _30D, _31D, _30D, _31D, _31D, _30D, _31D, _30D, _31D }; // 年
- 14long[] LeapYear = { _31D, _29D, _31D, _30D, _31D, _30D, _31D, _31D, _30D, _31D, _30D, _31D }; // 闰年
- 15static void Main(string[] args)
- 16{
- 17Program P = new Program();
- 18System.Console.WriteLine(P.getDate(P.getTimeSpame()));
- 19DateTime T = DateTime.Now;
- 20System.Console.WriteLine(P.getTimeSpame() + " : " + P.getTimeSpame(T.Year, T.Month, T.Day, T.Hour, T.Minute, T.Second));
- 21System.Console.ReadKey();
- 22}
- 23private Program() {}
- 24public string getDate(long TimeSp)
- 25{
- 26// 年,月,天,小时,分钟,秒
- 27int year = 0;
- 28int month = 0;
- 29int day = 0;
- 30int hour = 0;
- 31int minute = 0;
- 32int second = 0;
- 33//DateTime now = DateTime.Now;
- 34//long TimeSp = getTimeSpame(); // 当前时间戳
- 35// 年
- 36int _y1 = (int)(TimeSp / _YS); // 获得按年度得到的年度
- 37TimeSp -= _YS * _y1; // 计算剩余秒
- 38int _y2 = (int)(TimeSp / _1Y); // 剩余年
- 39TimeSp -= _1Y * _y2;
- 40year = _y1 * 4 + _y2 + 1970;
- 41// 月
- 42long[] YearArr = isLeapYear(year) ? LeapYear : NormalYear; // 获取年的月度表
- 43month = 1; // 从1月开始计算
- 44for (int i = 0; i < YearArr.Length; i++)
- 45{
- 46if (TimeSp - YearArr[i] < 0) break;
- 47++month;
- 48TimeSp -= YearArr[i];
- 49}
- 50// 天
- 51day = (int)(TimeSp / _1D);
- 52TimeSp -= day * _1D;
- 53// 时
- 54hour = (int)(TimeSp / _1H);
- 55TimeSp -= hour * _1H;
- 56// 分
- 57minute = (int)(TimeSp / _1M);
- 58// 秒
- 59second = (int)(TimeSp % _1M);
- 60string DateStr = year + "年" + month + "月" + day + "日 " + hour + "点" + minute + "分" + second + "秒";
- 61return DateStr;
- 62}
- 63// 判断是否闰年
- 64private bool isLeapYear(int year)
- 65{
- 66return (year % 4 == 0 ? true : false);
- 67}
- 68// 获取当前时间戳 按1970年开始计算,精度为秒!
- 69private long getTimeSpame()
- 70{
- 71DateTime _Now = DateTime.Now;
- 72DateTime _1970 = new DateTime(1970, 1, 1);
- 73long _Sp = (_Now.Ticks - _1970.Ticks) / 10000000;
- 74return _Sp;
- 75}
- 76// 按既定格式把时间转成成时间戳
- 77private long getTimeSpame(int Year, int Month, int Day, int Hour, int Minute, int Second)
- 78{
- 79long val = 0;
- 80val += Second; // 秒
- 81val += Minute * _1M; // 分钟
- 82val += Hour * _1H; // 小时
- 83val += Day * _1D; // 天
- 84long[] YearArr = isLeapYear(Year) ? LeapYear : NormalYear;
- 85for (int i = 0; i < Month - 1; i++)
- 86{
- 87val += YearArr[i];
- 88}
- 89Year -= 1970;
- 90val += (Year / 4) * _YS;
- 91Year -= (int)(Year / 4) * 4;
- 92val += Year * _1Y;
- 93return val;
- 94}
- 95}
三、JS时间戳转换方法:
代码如下:
- 01// 定义常量
- 02var _1M = 60; // 分钟
- 03var _1H = _1M * 60; // 小时
- 04var _1D = _1H * 24; // 天
- 05var _1Y = _1D * 365; // 年(非闰年)
- 06var _YS = _1Y * 3 + _1D * 366; // 一个闰年年度
- 07var _30D = _1D * 30; // 30天(月)
- 08var _31D = _1D * 31; // 31天(月)
- 09var _28D = _1D * 28; // 28天(月)
- 10var _29D = _1D * 29; // 29天(月)
- 11var NormalYear = [ _31D, _28D, _31D, _30D, _31D, _30D, _31D, _31D, _30D, _31D, _30D, _31D ]; // 年
- 12var LeapYear = [ _31D, _29D, _31D, _30D, _31D, _30D, _31D, _31D, _30D, _31D, _30D, _31D ]; // 闰年
- 13var Now = new Date();
- 14TimeSp = Now.getTime() / 1000;
- 15//alert(Now.getTimezoneOffset()); // 时区差
- 16TimeSp += -1 * Now.getTimezoneOffset() * _1M; // 修正UTC
- 17// 年,月,天,小时,分钟,秒
- 18var year = month = day = hour = minute = second = 0;
- 19// 年
- 20var _y1 = parseInt(TimeSp / _YS); // 获得按年度得到的年度
- 21TimeSp -= _YS * _y1; // 计算剩余秒
- 22var _y2 = parseInt(TimeSp / _1Y); // 剩余年
- 23TimeSp -= _1Y * _y2;
- 24year = _y1 * 4 + _y2 + 1970;
- 25// 月
- 26var YearArr = year % 4 == 0 ? LeapYear : NormalYear; // 获取年的月度表
- 27month = 1; // 从1月开始计算
- 28for (i=0; i<YearArr.length; i++)
- 29{
- 30if (TimeSp - YearArr[i] < 0) break;
- 31++month;
- 32TimeSp -= YearArr[i];
- 33}
- 34// 天
- 35day = parseInt(TimeSp / _1D);
- 36TimeSp -= day * _1D;
- 37// 时
- 38hour = parseInt(TimeSp / _1H);
- 39TimeSp -= hour * _1H;
- 40// 分
- 41minute = parseInt(TimeSp / _1M);
- 42// 秒
- 43second = parseInt(TimeSp % _1M);
- 44var DateStr = year + "年" + month + "月" + day + "日 " + hour + "点" + minute + "分" + second + "秒";
- 45alert(DateStr);
注:JS的Date对象的getTime()方法返回的是UTC的时间戳,可以使用getTimezoneOffset()的方法来返回与UTC时差的分钟。
以上代码便是MySQL、C#、JS的时间戳转换方法介绍,因为闰年的存在,代码的使用前请阅读一下。
以上就是关于「时间戳如何转换为日期格式?MySQL、C#、JS时间戳转换方法」的全部内容,本文讲解到这里啦,希望对大家有所帮助。如果你还想了解更多这方面的信息,记得收藏关注本站~
Win10系统之家独★家使★用,转载请注明出处!
相关文章
-
在当今社会上,形形色色的视频有很多,而每个视频都有它特定的格式。最近有用户遇到一个avi格式的视频,用户并不了解它,不知道avi是什么格式,又要如何将avi格式转换为flv格式。其实avi是一种音频视频交错格式,是将语音和影像同步组合在一起的文件格式。我们可以使用狸窝全能视频转换器来进行avi格式转换为flv格式。
方法/步骤
1、打开全能视频转换器,点击“添... -
想必熟悉格式工厂的用户都知道,格式工厂是一款支持转换所有主流格式的视频及音频文件的软件,但尽管格式工厂的功能很稳定也很强大,依旧还是会因为各种各样的原因导致转换出错,所以为了能及时知道错误并处理问题,我们最好是开启格式工厂的错误通知。下面,我们就一起往下看看格式工厂开启错误通知的方法吧!
方法步骤
1、打开格式工厂,点击进入上方的选项;
2、在界面... -
PDF文档怎么转换为CAD图纸?将PDF图导入到CAD中的方法
大部分的PDF文档都用于打印或出版制作,如果需要提取PDF文档中的内容,只能以页面图片的形式进行转换,有些CAD设计图也会以PDF文档的形式出现,这样的图纸看着很是不方便,更何况修改了,那有没有办法将PDF文档导入到CAD中预览呢?阅读下文了解PDF文档转换为CAD图纸的方法。
教程所用软件:
AdobeIllustratorCS4
操作步骤:
如今各大视频客户端为了能够更好的留住用户,都推出了自己固有的视频播放格式,比如优酷的KUX格式、爱奇艺的QSV格式和腾讯视频的QLV格式,这些专有格式只能在特定的播放器上播放。今天这篇文章就教大家如何将腾讯视频的QLV格式转换成MP4格式。
步骤一
1、首先将需要转换mp4格式的视频下载,要下载完成才能进行转换;
2、点击设置,将文件所在位置复制;...
- 软件教程
-
-
操作系统排行榜
更多>> -
- Ghost Win8.1 64位 老机精简专业版 V2023.02
- 【老机专用】Ghost Win8 32位 免费精简版 V2022.01
- 【致敬经典】Ghost Windows8 64位 免激活正式版 V2021.08
- 微软Windows8.1 32位专业版免激活 V2023.05
- Windows11 22H2 (22621.1778) X64 游戏美化版 V2023.06
- Windows11 22H2 (22621.1778) X64 专业精简版 V2023.06
- 笔记本专用 Ghost Win10 64位 专业激活版(适用各种品牌) V2022.08
- GHOST WIN8 X86 稳定专业版(免激活)V2022.07
- Windows8.1 64位 免费激活镜像文件 V2022.07
- Windows 8.1 64位 极速纯净版系统 V2022
-
软件教程排行榜
更多>> -
- Edge浏览器如何安装Flash?Edge浏览器安装Flash插件教程
- Excel如何锁定单元格不被修改?Excel锁定单元格的方法
- Epic游戏时如何打开自带帧数显示?Epic设置帧数显示的方法
- 谷歌浏览器如何提高文件下载速度?谷歌浏览器提高下载速度的方法
- 谷歌浏览器提示无法启动更新检查怎么办?谷歌浏览器无法启动更新检查的解决方法
- 360极速浏览器如何提高下载速度?360极速浏览器提高下载速度的方法
- Excel表格怎么换行?Excel单元格内换行的方法
- Excel表格斜线一分为二怎么弄?Excel表格斜线一分为二的方法
- Excel函数公式大全是什么?Excel函数公式大全介绍
- 雷电模拟器储存空间不足怎么办?雷电模拟器储存空间不足的解决方法
- 热门标签
-