golang 实现时间戳和时间的转化
- 作者: 亖呉?盀
- 来源: 51数据库
- 2021-08-20
说实话,golang的时间转化还是很麻烦的,最起码比php麻烦很多,上码好好学学一下
package main
import (
"time"
"fmt"
)
func main() {
//获取当前时间
t := time.now() //2018-07-11 15:07:51.8858085 +0800 cst m=+0.004000001
fmt.println(t)
//获取当前时间戳
fmt.println(t.unix()) //1531293019
//获得当前的时间
fmt.println(t.uninx().format("2006-01-02 15:04:05")) //2018-7-15 15:23:00
//时间 to 时间戳
loc, _ := time.loadlocation("asia/shanghai") //设置时区
tt, _ := time.parseinlocation("2006-01-02 15:04:05", "2018-07-11 15:07:51", loc) //2006-01-02 15:04:05是转换的格式如php的"y-m-d h:i:s"
fmt.println(tt.unix()) //1531292871
//时间戳 to 时间
tm := time.unix(1531293019, 0)
fmt.println(tm.format("2006-01-02 15:04:05")) //2018-07-11 15:10:19
//获取当前年月日,时分秒
y := t.year() //年
m := t.month() //月
d := t.day() //日
h := t.hour() //小时
i := t.minute() //分钟
s := t.second() //秒
fmt.println(y, m, d, h, i, s) //2018 july 11 15 24 59
}
补充:golang 13位时间戳转time.time
时间戳:
时间戳是使用数字签名技术产生的数据,签名的对象包括了原始文件信息、签名参数、签名时间等信息。时间戳系统用来产生和管理时间戳,对签名对象进行数字签名产生时间戳,以证明原始文件在签名时间之前已经存在。
mysql类型timestamp(时间戳)和datetime(时间)差别:
timestamp占用4个字节;
datetime占用8个字节;
timestamp范围1970-01-01 00:00:01.000000 到 2038-01-19 03:14:07.999999;
datetime是1000-01-01 00:00:00.000000 到 9999-12-31 23:59:59.999999;
时间戳格式:
10位数的时间戳是以 秒 为单位,如:1530027865
13位数的时间戳是以 毫秒 为单位, 如:1530027865231
19位数的时间戳是以 纳秒 为单位,如:1530027865231834600
golang获取当前时间或时间戳
// string
time.now().format("2006-01-02 15:04:05")
// time.time
time.now()
// int64 时间戳,默认10位,单位:秒
time.now().unixnano()
13位时间戳转时间格式
func unixtotime(e string) (datatime time.time, err error) {
data, err := strconv.parseint(e, 10, 64)
datatime = time.unix(data/1000, 0)
return
}
时间转13位时间戳
func timetounix(e time.time) int64 {
timeunix, _ := time.parse("2006-01-02 15:04:05", e.format("2006-01-02 15:04:05"))
return timeunix.unixnano() / 1e6
}
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
推荐阅读
