【Python】时间日期字符串之间的转换

版权声明:本文为博主原创文章,未经博主允许不得转载。谢谢您的关注... https://blog.csdn.net/u013948858/article/details/82774834

那些年strftime和strptime的故事...

python api 传送门:

https://docs.python.org/2/library/datetime.html?highlight=datetime#module-datetime

https://docs.python.org/2/library/time.html?highlight=time#module-time

time, datetime, string, timestamp之间相互转换

1. string 转换为其它

1.1 string --> datetime obj

>>> import datetime
>>> date_string = "2018-09-20 14:06:00"
>>> datetime.datetime.strptime(date_string, "%Y-%m-%d %H:%M:%S")
datetime.datetime(2018, 9, 20, 14, 6)

1.2 string --> time obj

>>> import time
>>> date_string = "2018-09-20 14:06:00"
>>> time.strptime(date_string, "%Y-%m-%d %H:%M:%S")
time.struct_time(tm_year=2018, tm_mon=9, tm_mday=20, tm_hour=14, tm_min=6, tm_sec=0, tm_wday=3, tm_yday=263, tm_isdst=-1)

2. datetime obj转换为其它

datetime obj转换为其它类型,用的都是datetime的函数

2.1 dt obj --> string

>>> import datetime
>>> date_obj = datetime.datetime(2018, 9, 20, 14, 6)
>>> date_obj.strftime("%Y-%m-%d %H:%M:%S")
'2018-09-20 14:06:00'

2.2 dt obj --> time obj

>>> import datetime
>>> date_obj = datetime.datetime(2018, 9, 20, 14, 6)
>>> date_obj.timetuple()
time.struct_time(tm_year=2018, tm_mon=9, tm_mday=20, tm_hour=14, tm_min=6, tm_sec=0, tm_wday=3, tm_yday=263, tm_isdst=-1)

3. time obj转换为其它

3.1 time obj --> string

>>> import time
>>> time_tuple = (2018,9,20,14,30,00,3,263,0)
>>> time.strftime("%Y-%m-%d %H:%M:%S", time_tuple)
'2018-09-20 14:30:00'

3.2 time obj --> datetime obj

>>> import time,datetime
>>> time_tuple = (2018,9,20,14,30,00,3,263,0)
>>> datetime.datetime(*time_tuple[0:6])
datetime.datetime(2018, 9, 20, 14, 30)

3.3 time obj --> timestamp

>>> import time
>>> time_tuple = (2018,9,20,14,30,00,3,263,0)
>>> time.mktime(time_tuple)
1537425000.0

4. timestamp转换为其它

 timestamp = 1480486369.75

注意以下两种都使用local时区

4.1 timestamp --> dt obj

>>> import datetime
>>> timestamp = 1537425000.0
>>> datetime.datetime.fromtimestamp(timestamp)
datetime.datetime(2018, 9, 20, 14, 30)

4.2 timestamp --> time obj

>>> import time
>>> timestamp = 1537425000.0
>>> time.localtime(timestamp)
time.struct_time(tm_year=2018, tm_mon=9, tm_mday=20, tm_hour=14, tm_min=30, tm_sec=0, tm_wday=3, tm_yday=263, tm_isdst=0)

-以下两种方式和时区相关,比较标准时区时间和本地时区时间

4.3 使用UTC --> dt obj

#本地时区时间 同 4.1

#标准时区时间

>>> import datetime
>>> timestamp = 1537425000.0
>>> datetime.datetime.utcfromtimestamp(timestamp)
datetime.datetime(2018, 9, 20, 6, 30)

4.4 使用UTC --> time obj

#本地时区时间 同 4.2

#标准时区时间

>>> import time
>>> timestamp = 1537425000.0
>>> time.gmtime(timestamp)
time.struct_time(tm_year=2018, tm_mon=9, tm_mday=20, tm_hour=6, tm_min=30, tm_sec=0, tm_wday=3, tm_yday=263, tm_isdst=0)

备注:

python几种日期的表现形式:time, datetime, string, timestamp

1. time string

string是最简单的表示time的方式

>>> import time
>>> time.ctime()
'Thu Sep 20 14:00:00 2018'

or 

time_string = '2018-09-20 13:54:05'

2. datetime tuple(datetime obj)

datetime tuple是datetime.datetime对象类型

>>> import datetime
>>> datetime.datetime.now()
datetime.datetime(2018, 9, 20, 14, 4, 24, 617000)

3. time tuple(time obj)

time tuple是time.struct_time对象类型

>>> date_string = "2018-09-20 14:06:00"
>>> time.strptime(date_string, "%Y-%m-%d %H:%M:%S")
time.struct_time(tm_year=2018, tm_mon=9, tm_mday=20, tm_hour=14, tm_min=6, tm_sec=0, tm_wday=3, tm_yday=263, tm_isdst=-1)

4. timestamp

时间戳类型:自1970年1月1日(00:00:00 GMT)以来的秒数(乘以1000是毫秒)

>>> import time
>>> time.time()
1537423675.563

格式化占位符

格式字符  意义
%a 星期的简写。如 星期三为Web
%A 星期的全写。如 星期三为Wednesday
%b 月份的简写。如4月份为Apr
%B 月份的全写。如4月份为April
%c:  日期时间的字符串表示。(如: 04/07/10 10:43:39)
%d:  日在这个月中的天数(是这个月的第几天)
%f:  微秒(范围[0,999999])
%H:  小时(24小时制,[0, 23])
%I:  小时(12小时制,[0, 11])
%j:  日在年中的天数 [001,366](是当年的第几天)
%m:  月份([01,12])
%M:  分钟([00,59])
%p:  AM或者PM
%S:  秒(范围为[00,61],为什么不是[00, 59],参考python手册~_~)
%U:  周在当年的周数当年的第几周),星期天作为周的第一天
%w:  今天在这周的天数,范围为[0, 6],6表示星期天
%W:  周在当年的周数(是当年的第几周),星期一作为周的第一天
%x:  日期字符串(如:04/07/10)
%X:  时间字符串(如:10:43:39)
%y:  2个数字表示的年份
%Y:  4个数字表示的年份
%z:  与utc时间的间隔 (如果是本地时间,返回空字符串)
%Z:  时区名称(如果是本地时间,返回空字符串)
%%:  %% => %

猜你喜欢

转载自blog.csdn.net/u013948858/article/details/82774834