GoLong的学习之路(十四)语法之标准库 time(时间包)的使用

2023-10-28 15:15

本文主要是介绍GoLong的学习之路(十四)语法之标准库 time(时间包)的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • time包
    • 跨时区
    • 时间戳
    • 时间间隔
    • 时间操作
      • add
      • Sub
      • Equal
      • Before
      • After
    • 定时器
    • 时间格式化
    • 解析字符串格式的时间

time包

时间和日期是我们编程中经常会用到的,本文主要介绍了 Go 语言内置的 time 包的基本用法。

  • time 包提供了一些关于时间显示和测量用的函数。
  • time 包中日历的计算采用的是公历,不考虑润秒。

Go 语言中使用time.Time类型表示时间。我们可以通过time.Now函数获取当前的时间对象,然后从时间对象中可以获取到年、月、日、时、分、秒等信息。

// timeDemo 时间对象的年月日时分秒
func timeDemo() {now := time.Now() // 获取当前时间fmt.Printf("current time:%v\n", now)year := now.Year()     // 年month := now.Month()   // 月day := now.Day()       // 日hour := now.Hour()     // 小时minute := now.Minute() // 分钟second := now.Second() // 秒fmt.Println(year, month, day, hour, minute, second)
}

跨时区

Go 语言中使用 location 来映射具体的时区。时区(Time Zone)是根据世界各国家与地区不同的经度而划分的时间定义,全球共分为24个时区。

中国差不多跨5个时区(壮哉我中国,地大物博),为了时区的一致,在国内通常使用的是北京的时区。

下面的示例代码中使用beijing来表示东八区8小时的偏移量,其中time.FixedZone和time.LoadLocation这两个函数则是用来获取location信息。

// timezoneDemo 时区示例
func timezoneDemo() {// 中国没有夏令时,使用一个固定的8小时的UTC时差。// 对于很多其他国家需要考虑夏令时。secondsEastOfUTC := int((8 * time.Hour).Seconds())// FixedZone 返回始终使用给定区域名称和偏移量(UTC 以东秒)的 Location。beijing := time.FixedZone("Beijing Time", secondsEastOfUTC)// 如果当前系统有时区数据库,则可以加载一个位置得到对应的时区// 例如,加载纽约所在的时区newYork, err := time.LoadLocation("America/New_York") // UTC-05:00if err != nil {fmt.Println("load America/New_York location failed", err)return}fmt.Println()// 加载上海所在的时区//shanghai, err := time.LoadLocation("Asia/Shanghai") // UTC+08:00// 加载东京所在的时区//tokyo, err := time.LoadLocation("Asia/Tokyo") // UTC+09:00// 创建时间对象需要指定位置。常用的位置是 time.Local(当地时间) 和 time.UTC(UTC时间)。//timeInLocal := time.Date(2023, 10, 27, 20, 0, 0, 0, time.Local)  // 系统本地时间timeInUTC := time.Date(2023, 10, 27, 12, 0, 0, 0, time.UTC)sameTimeInBeijing := time.Date(2023, 10, 27, 20, 0, 0,  beijing)sameTimeInNewYork := time.Date(2009, 1, 1, 7, 0, 0, 0, newYork)// 北京时间(东八区)比UTC早8小时,所以上面两个时间看似差了8小时,但表示的是同一个时间timesAreEqual := timeInUTC.Equal(sameTimeInBeijing)fmt.Println(timesAreEqual)// 纽约(西五区)比UTC晚5小时,所以上面两个时间看似差了5小时,但表示的是同一个时间timesAreEqual = timeInUTC.Equal(sameTimeInNewYork)fmt.Println(timesAreEqual)
}

注意
由于time.loadLocation 依赖系统的时区数据库,在不确定程序的运行环境的情况下建议先定义时区偏移量,然后使用time.FixedZone 的方式指定时区。

(这个我遇到过,你们敢信,在这个时代,我曾经遇到过一个xp系统的电脑。人还不会配置时间,系统时间就有问题。所以一定不能依赖系统的时区数据库)

时间戳

Unix Time是自1970年1月1日 00:00:00 UTC 至当前时间经过的总秒数。

// timestampDemo 时间戳
func timestampDemo() {now := time.Now()        // 获取当前时间timestamp := now.Unix()  // 秒级时间戳milli := now.UnixMilli() // 毫秒时间戳 Go1.17+micro := now.UnixMicro() // 微秒时间戳 Go1.17+nano := now.UnixNano()   // 纳秒时间戳fmt.Println(timestamp, milli, micro, nano)
}

time 包还提供了一系列将 int64 类型的时间戳转换为时间对象的方法。

这里注意还是得转换一下时区

secondsEastOfUTC := int((8 * time.Hour).Seconds())beijing := time.FixedZone("Beijing Time", secondsEastOfUTC)// 北京时间 2022-02-22 22:22:22.000000022 +0800 CSTt := time.Date(2022, 02, 22, 22, 22, 22, 22, beijing)
var (sec  = t.Unix()msec = t.UnixMilli()usec = t.UnixMicro())// 将秒级时间戳转为时间对象(第二个参数为不足1秒的纳秒数)timeObj := time.Unix(sec, 22)fmt.Println(timeObj)           // 2022-02-22 22:22:22.000000022 +0800 CSTtimeObj = time.UnixMilli(msec) // 毫秒级时间戳转为时间对象fmt.Println(timeObj)           // 2022-02-22 22:22:22 +0800 CSTtimeObj = time.UnixMicro(usec) // 微秒级时间戳转为时间对象fmt.Println(timeObj)           // 2022-02-22 22:22:22 +0800 CST

时间间隔

time.Duration是time包定义的一个类型,它代表两个时间点之间经过的时间,以纳秒为单位。

time.Duration表示一段时间间隔,可表示的最长时间段大约290年。

time.Duration表示1纳秒,time.Second表示1秒。

const (Nanosecond  Duration = 1Microsecond          = 1000 * NanosecondMillisecond          = 1000 * MicrosecondSecond               = 1000 * MillisecondMinute               = 60 * SecondHour                 = 60 * Minute
)

源码

在这里插入图片描述

时间操作

add

func (t Time) Add(d Duration) Time
func main() {now := time.Now()later := now.Add(time.Hour) // 当前时间加1小时后的时间fmt.Println(later)
}

Sub

func (t Time) Sub(u Time) Duration

返回一个时间段t-u。

如果结果超出了Duration可以表示的最大值最小值,将返回最大值最小值

要获取时间点t-d(d为Duration),可以使用t.Add(-d)。

Equal

func (t Time) Equal(u Time) bool

判断两个时间是否相同,会考虑时区的影响,因此不同时区标准的时间也可以正确比较。

这个方法和用t==u不同,这种方法还会比较地点和时区信息。

Before

func (t Time) Before(u Time) bool

如果t代表的时间点在u之前,返回真;否则返回假。

After

func (t Time) After(u Time) bool

如果t代表的时间点在u之后,返回真;否则返回假。

定时器

使用time.Tick(时间间隔)来设置定时器,定时器的本质上是一个通道(channel)

func tickDemo() {ticker := time.Tick(time.Second) //定义一个1秒间隔的定时器for i := range ticker {fmt.Println(i)//每秒都会执行的任务}
}

时间格式化

time.Format函数能够将一个时间对象格式化输出为指定布局的文本表示形式,需要注意的是 Go 语言中时间格式化的布局不是常见的Y-m-d H:M:S,而是使用2023-10-27 15:04:05.000

  • 如果想格式化为12小时格式,需在格式化布局中添加PM。
  • 小数部分想保留指定位数就写0,如果想省略末尾可能的0就写 9。
// formatDemo 时间格式化
func formatDemo() {now := time.Now()// 格式化的模板为 2006-01-02 15:04:05// 24小时制fmt.Println(now.Format("2006-01-02 15:04:05.000 Mon Jan"))// 12小时制fmt.Println(now.Format("2006-01-02 03:04:05.000 PM Mon Jan"))// 小数点后写0,因为有3个0所以格式化输出的结果也保留3位小数fmt.Println(now.Format("2006/01/02 15:04:05.000")) // 2022/02/27 00:10:42.960// 小数点后写9,会省略末尾可能出现的0fmt.Println(now.Format("2006/01/02 15:04:05.999")) // 2022/02/27 00:10:42.96// 只格式化时分秒部分fmt.Println(now.Format("15:04:05"))// 只格式化日期部分fmt.Println(now.Format("2006.01.02"))
}

在这里插入图片描述

解析字符串格式的时间

对于从文本的时间表示中解析出时间对象,time包中提供了time.Parse和time.ParseInLocation两个函数。

其中time.Parse在解析时不需要额外指定时区信息。

// parseDemo 指定时区解析时间
func parseDemo() {// 在没有时区指示符的情况下,time.Parse 返回UTC时间timeObj, err := time.Parse("2006/01/02 15:04:05", "2022/10/05 11:25:20")if err != nil {fmt.Println(err)return}fmt.Println(timeObj) // 2022-10-05 11:25:20 +0000 UTC// 在有时区指示符的情况下,time.Parse 返回对应时区的时间表示// RFC3339     = "2006-01-02T15:04:05Z07:00"timeObj, err = time.Parse(time.RFC3339, "2023-10-05T11:25:20+08:00")if err != nil {fmt.Println(err)return}fmt.Println(timeObj) // 2022-10-05 11:25:20 +0800 CST
}

在这里插入图片描述

time.ParseInLocation函数需要在解析时额外指定时区信息。

func parseDemo() {now := time.Now()fmt.Println(now)// 加载时区loc, err := time.LoadLocation("Asia/Shanghai")if err != nil {fmt.Println(err)return}// 按照指定时区和指定格式解析字符串时间timeObj, err := time.ParseInLocation("2006/01/02 15:04:05", "2022/10/05 11:25:20", loc)if err != nil {fmt.Println(err)return}fmt.Println(timeObj)fmt.Println(timeObj.Sub(now))
}

在这里插入图片描述

这篇关于GoLong的学习之路(十四)语法之标准库 time(时间包)的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/294086

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传