python 数据类型转换解决1970年问题_Python 时间类型处理

在数据分析的过程中,经常面临各种时间获取,类型转换的问题;本文主要讲解 Python语言中 时间类型之间的转换,以及pandas中的时间处理。

1 标准时间处理库

Python 标准库中有两个处理时间的库。其中一个名为 datetime,另一个是time。

在 Python 官网文档中,datetime 是被定义为数据类型(Data Types)。由此可见,datetime 是主要提供处理日期和时间的数据类型的模块。它其中有几个常用的类型,例如:datetime.datetime、datetime.time、datetime.date 等,其中最主要的类是datetime.datetime。因为它携带了 datetime.time 和 datetime.date 这两个所带的信息,能够比较齐全地输出,即能一次性就输出年、月、日、时、分、秒等日期和时间信息。

time 模块是归属于通用操作系统服务(Generic Operating System Services)类目中。time 模块主要提供各种时间转换的函数。它服务于系统层次,Python 又是跨平台的,所以有些 API 只能在某些操作系统上使用。

1.1 时间对象类型

在 Python 中,涉及时间对象有 4 种:

1)datetime

2)timestamp

3)time tuple

4)string

1.2 类型转换及代码

现实中会经常遇到 datetime string的相互转换,主要通过strftime, strptime函数来完成。

import datetime

# return datetime类型

now = datetime.datetime.now()

print(now)

print(type(now))

""">> 2019-12-02 15:22:35.176142>> """

# datetime 转 string

str_now = datetime.datetime.now().strftime("%Y-%m-%d%H:%M:%S")

print(str_now)

""">> '2019-12-02 14:40:35'"""

# string 转 datetime

t1 = '2019-12-02 14:40:35'

t2 = datetime.datetime.strptime(t1, "%Y-%m-%d%H:%M:%S")

print(t2)

print(type(t2))

""">> 2019-12-02 14:40:35>> """

timestamp 指的是 Unix 时间戳。它是格林威治时间 1970 年 01 月 01 日 00 时 00 分 00 秒(北京时间 1970 年 01 月 01 日 08 时 00 分 00 秒)起至现在的总秒数。我们使用 time 对象中的time()函数能获取到时间戳

import time

# 通过time库 获取当前时间戳

now_timestamp = time.time()

print(now)

print(type(now))

""">> 1575272037.5272005>> """

now_tuple = time.localtime()

print(now_tuple )

print(type(now_tuple))

""">> time.struct_time(tm_year=2019, tm_mon=12, tm_mday=2, tm_hour=14, tm_min=42, tm_sec=44, tm_wday=0, tm_yday=336, tm_isdst=0)>> """

1.3 类型转换图类型转换主要上前辈整理的示意图

2 pandas中时间数据类型转换

实际工作中我们通常使用pandas来进行数据的读取,分析等;因此,对于pandas中的时间对象类型 与 Python时间对象的转换也要十分清楚。

可以通过pandas中to_datetime函数进行时间数据类型转换

后续,可以通过dataframe 时间序列索引的方式去 获取,处理数据。

参考文档:极客猴:Python 中各种时间类型的转换​zhuanlan.zhihu.com

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值