golang 实现时间戳和时间的转化
说实话,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 }
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。
最新评论