记录时间和时间格式的转换,在程序中应用广泛,基本所有语言自带点处理时间和日期的函数,什么转换成带时区,不带时区,精确到年,月,日,时,分,甚至精确到秒,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开始以秒为单位的时间间隔整数
这就需要转换成可读的格式 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运行一下:
原因就是出在变量类型上,让我们console一下看看:
敲黑板。重点来了。请问一加一在什么情况下不等于2,答:在字符串相加的情况下(1+1=11,数字相加1+1=2)。
两种方法供你选择:
3)如何转换成双字符?比如
这是你需要让电脑判断一下你的整数是否为两位数,如果不足为,前面补零,自己写写看:
补位要字符串相加,所以不是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()输出