时间转换这点事儿

记录时间和时间格式的转换,在程序中应用广泛,基本所有语言自带点处理时间和日期的函数,什么转换成带时区,不带时区,精确到年,月,日,时,分,甚至精确到秒,24h制的,12h制的。看似足够多足够全面,但是自己一用就发现,讨厌,都不是自己想要的格式。拿个纸笔自己算吧,除六十,再除60,等等这是该进位了吧。。。就问你晕不晕,烦不烦。


先来介绍两个时间概念

有时区的时间(timestamp with timezone):本地时间,也就是数据库服务器的时区改了,或者把应用服务器的时区(北京时间比UTC时间快8个小时)

无时区的时间(timestamp without timezone):当前时间是指从一个基准时间(1970-1-1 00:00:00 +0:00),到现在的秒数,用一个整数表示。

一般数据库存时间戳都是用的第二种,别问我为什么,都是血的教训。服务器的时区一个不小心手滑选成了某个不知名的地区,自动储存的时间戳天知道真实时间是几点,还得Google一下对应关系,自己手动转换。。。


再就是举几个开发语言自带对于时间转化功能(以JavaScript为例):

这种Date类型的方法,还有一些常见用法,网上一搜一大堆,这里推荐一个https://blog.csdn.net/ligang2585116/article/details/52145580最好的理解方法还是自己跑跑,试试看。

还有个第三方插件moment.js  https://momentjs.com/ 用的时候自己找找document对应自己需要的功能。


在以上均不能满足需求之后,让我们来自己写一写:

做simulation的时候往往拿到的是从0开始以秒为单位的时间间隔整数

video常见Json文件

这就需要转换成可读的格式 00:00:00.在此我们假定起始记录时间为06:00:00

思考过程如下:

1)如何确定小时:1h=60min=60*60s=>1s=1/(60*1000)min=1/(60*60)h. 现有时间为秒,那么当然是来个除法啦,得到结果3.2小时怎么办?当然是向下取整,切记可别四舍五入!!超过24h怎么办?取余取余,25h人话叫1Day1h.

2)然后你只需要Google 一下“js 如何向下取整,如何进行数学运算”,然后就是大胆的试

看起来貌似没什么问题,但是。。。

好,ctrl+B运行一下:

这176是神马玩意!!!

原因就是出在变量类型上,让我们console一下看看:

这就是原因

敲黑板。重点来了。请问一加一在什么情况下不等于2,答:在字符串相加的情况下(1+1=11,数字相加1+1=2)。

两种方法供你选择:

定义一个变量是数字
Number()强制类型转换

3)如何转换成双字符?比如

你别指望电脑能自己把7变成07

这是你需要让电脑判断一下你的整数是否为两位数,如果不足为,前面补零,自己写写看:

你要是这么写,我要打你了。。。
怎么没变化
看出来区别了吗?

补位要字符串相加,所以不是0 是“0”.


同样的方法计算并处理分钟和秒数:

你以为这样就完事了!!!

24小时制度对于老年人来说还是不那么友好,让我们来进一步改成给易读的12小时制度吧。

思考过程如下:

1)我们是怎么区分AM和PM的呢?以正午12点为界限,如果小时数超过12,那么就是PM,等于12,如果分钟数大于0那么就是PM,12:00:00依然是AM。

2)输入格式为hh:mm:ss,当然以“:”为分隔识别符,就很轻易将时分秒提取出来。

3)自行Google并学习split()如何使用。

完美

现在我们已经有了普遍适用的原创function,当然从性能或者效率来说一定有更好的,但是重要的不是结果而是整个思考过程。学习不是抄袭,别人的码终归是别人的,首先你得往前走,然后再往高处看。

至少现在你应该掌握:

1)字符串和数字的转换

2)字符串的加减以及数字的加减

3)逻辑运算,与或非。比较大小,取余,取整等一系列JS中Math的相关使用

4)字符串的分隔split()使用,数组使用

5)  如何定义一个函数,如何传参,回调

6)console.log()输出

你可能感兴趣的:(时间转换这点事儿)