python时间模块的使用 white_study

Souleigh ✨
• 阅读 1749
前言:

在开发中经常会与时间打交道,如:获取事件戳,时间戳的格式化等,这里简要记录一下python操作时间的方法。

python中常见的处理时间的模块:
  • time:处理时间的模块,如获取时间戳,格式化日期等
  • datetime:date和time的结合体,处理日期和时间
  • calendar:日历相关的模块,如:处理年历/月历
time模块介绍
说明:time模块主要讲解如下内容:
  • 1.时间戳 --> 时间元组格式(time.struct_time) --> 日期字符串
  • 2.日期字符串 --> 时间元组格式(time.struct_time) --> 时间戳
  • 3.获取当前时间的分钟/秒
  • 4.获取整分钟/整小时时间戳

1.时间戳 --> 时间元组格式(time.struct_time) --> 日期字符串

  • 时间戳 --> 时间元组格式
    time.localtime(timestamp) # 参数timestamp为秒级时间戳
  • 例子:
import time

time_tuple = time.localtime(time.time())
print time_tuple  # time.struct_time(tm_year=2019, tm_mon=1, tm_mday=30, tm_hour=11, tm_min=29, tm_sec=33, tm_wday=2, tm_yday=30, tm_isdst=0) 
  • 时间元组 --> 日期字符串
    time.strftime(format, p_tuple=None):format:格式化的日期样式;p_tuple:时间元组
  • 例子:
time_format = time.strftime("%Y-%m-%d %H:%M:%S", time_tuple)
print time_format  # 2019-01-30 11:48:07 
  • 封装成方法:
def timestamp_format(timestamp):
    """
    :brief  时间戳格式化
    :param timestamp: 时间戳
    :return: 格式化后的日期
    """
    return time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(timestamp)) 

2.日期字符串 --> 时间元组格式(time.struct_time) --> 时间戳

  • 日期字符串 --> 时间元组
    time.strptime(string, format) # string:日期字符串,format:该日期字符串对应的格式化格式
  • 例子:
import time

time_str_to_tuple = time.strptime("2019-01-30 11:48:07", "%Y-%m-%d %H:%M:%S")
print time_str_to_tuple  # time.struct_time(tm_year=2019, tm_mon=1, tm_mday=30, tm_hour=11, tm_min=48, tm_sec=7, tm_wday=2, tm_yday=30, tm_isdst=-1) 
  • 时间元组 --> 时间戳
    time.mktime(p_tuple):p_tuple:时间元组
  • 例子:
time_tuple_to_timestamp = int(time.mktime(time_str_to_tuple))
print time_tuple_to_timestamp  # 结果:1548820087 
  • 封装成方法
def time_str_to_timestamp(date_str, format):
    """
    :brief 将字符串日期转换为时间戳
    :param date_str: 日期字符串,如:2019-01-30 11:48:07
    :param format: 日期字符串对应的格式化格式,如:%Y-%m-%d %H:%M:%S
    :return: 时间戳
    """
    return int(time.mktime(time.strptime(date_str, format))) 

3.获取当前时间的分钟/秒

  • 获取当前时间戳
timestamp = int(time.time()) 
  • 获取当前时间的秒
seconds = timestamp % 60
print "seconds:{}".format(seconds) 
  • 获取当前时间的分钟
minute = (timestamp - seconds) % (60 * 60)
print "minute:{}".format(minute / 60) 

4.获取整分钟/整小时时间戳

  • 思路:
    先除以对应的进制值取整,得到舍弃余数部分的整数,然后再乘以对应的进制值
one_minute = 60  # 一分钟
one_hour = one_minute * 60  # 一小时

whole_minute = int(timestamp / one_minute) * one_minute
whole_hour = int(timestamp / one_hour) * one_hour 
datetime模块介绍
datetime模块中常见的类:
  • datetime.date:处理日期
  • datetime.time:处理时间
  • datetime.datetime:处理日期和时间
  • datetime.timedelta:处理时间差
说明:datetime模块主要讲解如下内容
  • 1.时间戳 --> datetime时间格式 --> 日期字符串
  • 2.日期字符串 --> datetime时间格式 --> 时间元组格式(time.struct_time) --> 时间戳
  • 3.时间差的使用,根据当前时间获取前N天的时间

1.时间戳 --> datetime时间格式 --> 日期字符串

  • 时间戳 --> datetime时间格式
    datetime.datetime.fromtimestamp(timestamp) 参数timestamp:时间戳
  • 例子:
import time, datetime

datetime_type = datetime.datetime.fromtimestamp(time.time())
print type(datetime_type)  # <type 'datetime.datetime'> 
  • datetime时间格式 --> 日期字符串
    datetime.datetime.strftime(format) format:日期字符串对应的格式化格式
  • 例子:
datetime_format = datetime_type.strftime("%Y/%m/%d %H:%M:%S")
print datetime_format  # 2019/01/30 16:44:01 

2.日期字符串 --> datetime时间格式 --> 时间元组格式(time.struct_time) --> 时间戳

  • 日期字符串 --> datetime时间格式
    datetime.datetime.strptime(date_str, format) date_str:字符串日期 format:日期字符串对应的格式化格式
  • 例子:
datetime_type = datetime.datetime.strptime('2019/01/30 16:44:01', '%Y/%m/%d %H:%M:%S')
print type(datetime_type)  # <type 'datetime.datetime'>
# print datetime_type.timestamp()
print time.mktime(datetime_type.timetuple()) 
  • datetime时间格式 --> 时间元组格式(time.struct_time) --> 时间戳
    datetime.datetime.timetuple(): datetime转换为时间元组
  • 例子:
datetime_type_to_timestamp = int(time.mktime(datetime_type.timetuple()))
print datetime_type_to_timestamp 

3.时间差的使用,根据当前时间获取前N天的时间
datetime.timedelta(days, seconds, microseconds, milliseconds, minutes, hours, weeks)
参数说明:
1.days:天
2.seconds:秒
3.microseconds:毫秒 1秒 = 10^3 毫秒
4.milliseconds:微秒 1秒 = 10^6 微秒
5.minutes,分钟
6.hours:小时
7.weeks:星期 1weeks = 7days

  • 例子:
day_timedelta = datetime.timedelta(days=1)  # 获取1天的时间值
forward_datetime = datetime.datetime.today() - day_timedelta  # 获取前一天的datetime值
print forward_datetime 
calendar模块介绍
说明:

这里介绍一下使用month(year, month)方法打印出某年某月下的月历时间

例子:
import calendar
cal = calendar.month(2019, 1)  # 打印出2019年1月的月历
print cal 

喜欢点个赞!

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Wesley13 Wesley13
3年前
java常用类(2)
三、时间处理相关类Date类:计算机世界把1970年1月1号定为基准时间,每个度量单位是毫秒(1秒的千分之一),用long类型的变量表示时间。Date分配Date对象并初始化对象,以表示自从标准基准时间(称为“历元”(epoch),即1970年1月1日08:00:00GMT)以来的指定毫秒数。示例:packagecn.tanjian
Karen110 Karen110
3年前
​一篇文章总结一下Python库中关于时间的常见操作
前言本次来总结一下关于Python时间的相关操作,有一个有趣的问题。如果你的业务用不到时间相关的操作,你的业务基本上会一直用不到。但是如果你的业务一旦用到了时间操作,你就会发现,淦,到处都是时间操作。。。所以思来想去,还是总结一下吧,本次会采用类型注解方式。time包importtime时间戳从1970年1月1日00:00:00标准时区诞生到现在
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
3年前
Java日期时间API系列31
  时间戳是指格林威治时间1970年01月01日00时00分00秒起至现在的总毫秒数,是所有时间的基础,其他时间可以通过时间戳转换得到。Java中本来已经有相关获取时间戳的方法,Java8后增加新的类Instant等专用于处理时间戳问题。 1获取时间戳的方法和性能对比1.1获取时间戳方法Java8以前
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
3年前
HIVE 时间操作函数
日期函数UNIX时间戳转日期函数: from\_unixtime语法:   from\_unixtime(bigint unixtime\, string format\)返回值: string说明: 转化UNIX时间戳(从19700101 00:00:00 UTC到指定时间的秒数)到当前时区的时间格式举例:hive   selec
Stella981 Stella981
3年前
Python time模块 返回格式化时间
常用命令  strftimetime.strftime("%Y%m%d%H:%M:%S",formattime)第二个参数为可选参数,不填第二个参数则返回格式化后的当前时间日期201812112:00:00time.strftime('%H:%M:%S')返回当前时间的时分秒time.strftim
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_