[工具类]将时间转换为unix时间戳格式

简介:

写在前面

由于在数据库中存的时间有时间戳格式的数据,在解析以及保存的时候,就需要考虑到数据格式的兼容性问题。看到数据库中的时间字段基本上都是以时间戳格式存储的,没办法,只能将时间进行转换了,考虑到其他系统可能要对时间字段进行操作,就不得不考虑时间的兼容性了。

时间戳辅助类

什么是时间戳?

Unix时间戳(Unix timestamp),或称Unix时间(Unix time)、POSIX时间(POSIX time),是一种时间表示方式,定义为从格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数。Unix时间戳不仅被使用在Unix系统、类Unix系统中(比如Linux系统),也在许多其他操作系统中被广泛采用。
php中获取时间戳的方法是:time();Date();
Linux中获取时间戳的方法是:date +%s
Linux中将时间戳转换为日期: date -d "@<timestamp>"

既然知道了基准时间为1970年01月01日00时00分00秒,那么转换为时间戳就很容易了。

复制代码
 1     /// <summary>
 2     ///日期转换辅助类
 3     /// </summary>
 4     public static class DateHelper
 5     {
 6 
 7         public static DateTime ConvertTime(string datatime)
 8         {
 9             Int64 timeStamp = Convert.ToInt64(datatime);
10             DateTime dtStart = TimeZone.CurrentTimeZone.ToLocalTime(new DateTime(1970, 1, 1));
11             TimeSpan toNow = new TimeSpan(timeStamp * 10000);
12             return dtStart.Add(toNow);
13         }
14 
15         /// <summary>
16         /// 将c# DateTime时间格式转换为Unix时间戳格式
17         /// </summary>
18         /// <param name="time">时间</param>
19         /// <returns>long</returns>
20         public static long ConvertTime2Long(System.DateTime time)
21         {
22             System.DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(1970, 1, 1, 0, 0, 0, 0));
23             long t = (time.Ticks - startTime.Ticks) / 10000;            //除10000调整为13位
24             return t;
25         }
26 
27     }
复制代码

简单测试

复制代码
 1     class Program
 2     {
 3         static void Main(string[] args)
 4         {
 5             long result = DateHelper.ConvertTime2Long(DateTime.Now);
 6             Console.WriteLine("时间戳:" + result);
 7             DateTime dt = DateHelper.ConvertTime(result.ToString());
 8             Console.WriteLine("时间:"+dt.ToString());
 9             Console.Read();
10         }
11     }
复制代码

博客地址: http://www.cnblogs.com/wolf-sun/
博客版权: 本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。
如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步!
再次感谢您耐心的读完本篇文章。http://www.cnblogs.com/wolf-sun/p/4471768.html

相关文章
|
5月前
|
Unix Linux Shell
【文件格式问题】文件格式 Windows、Unix/Linux、Mac 导致的问题及处理(idea 或 notepad++ 档案格式转换方法)
【文件格式问题】文件格式 Windows、Unix/Linux、Mac 导致的问题及处理(idea 或 notepad++ 档案格式转换方法)
62 0
|
Unix
遇到的各种时间类型:UTC时间、GMT时间、本地时间、Unix时间戳
每次遇到各种时间傻傻分不清,特意记录一下,给自己提个醒。
223 0
|
Ubuntu Unix Python
[oeasy]python0024_unix时间戳_epoch_localtime_asctime_PosixTime_unix纪年法
[oeasy]python0024_unix时间戳_epoch_localtime_asctime_PosixTime_unix纪年法
73 2
|
Unix API C语言
UNIX时间戳和北京时间的相互转换
UNIX时间戳和北京时间的相互转换
560 0
UNIX时间戳和北京时间的相互转换
|
移动开发 Unix Linux
一文搞清UNIX/Linux与Windows文件换行符格式差异
一文搞清UNIX/Linux与Windows文件换行符格式差异
304 0
一文搞清UNIX/Linux与Windows文件换行符格式差异
|
关系型数据库 MySQL Unix
mysql,如何在Unix和Mysql时间戳之间进行转换?
mysql,如何在Unix和Mysql时间戳之间进行转换?
125 0
|
SQL 存储 Unix
【Hive】FROM_UNIXTIME() 和 UNIX_TIMESTAMP()时间戳函数用法
【Hive】FROM_UNIXTIME() 和 UNIX_TIMESTAMP()时间戳函数用法
1260 0
|
存储 前端开发 Unix
Mysql - 如何存储 10位、13位的 unix 时间戳?
Mysql - 如何存储 10位、13位的 unix 时间戳?
429 0
|
Unix 关系型数据库 MySQL
Unix时间戳
Unix时间戳
396 0
|
搜索推荐 Java Unix
【小知识大用处】Java与Unix时间戳互转
【小知识大用处】Java与Unix时间戳互转
355 0