当前位置:   article > 正文

python datetime、字符串和时间戳之间的相互转换&&12小时制和24小时制时间相互转化_python datetime转时间戳

python datetime转时间戳


1.字符串转datetime格式

把字符串转换为datetime的格式

项目字符串的样子
‘%m/%d/%Y %H:%M:%S’2/3/2023 15:30:20
‘%m-%d-%Y %H-%M-%S’2-3-2023 15-30-20

注意上面只是一个例子,年月日时分秒这些可以根据自己的数据来调整顺序,中间的连接符也是一样可以调整

from datetime import datetime, timedelta
time_str = '2/3/2023 15:30:20'
formated_time = datetime.strptime(time_str, '%m/%d/%Y %H:%M:%S')
  • 1
  • 2
  • 3

2.datetime转字符串

__format__方法可以将datetime格式的时间,转化为想要的字符串,下面分别获得年、月,写上对应的时间格式,如%m/%d/%Y %H:%M:%S,可以获得年月日时分秒的字符串

project_first_day = dt.today()
curr_year = project_first_day.__format__("%Y")
curr_mon = project_first_day.__format__("%m")
  • 1
  • 2
  • 3

3.时间戳转datetime格式

时间戳转换为datetime格式

project_start_day =  dt.fromtimestamp(200755513)
  • 1

4.datetime格式转时间戳

final_time.timestamp() # final_time为datetime格式
  • 1

5.应用:将12小时制的字符串转换为时间戳

问题:有12小时制的时间字符串,如2/16/2023 7:11:46 PM, 2/16/2023 12:05:06 AM,希望将这些字符串转换为时间戳,以存储到数据库
思路:

  1. 分割字符串时间部分和早晚am/pm标记
  2. 将字符串时间部分先转换为datetime格式
  3. 根据PM和AM决定是否需要再时间上加12小时
  4. 将datetime转换为时间戳
	def transform_12sys_time_to_timestamp(self, time_in_12_sys):
        '''
        desc: transform time in 12 system to time stamp
        @param time_in_12_sys: for example '4/6/2022 3:09:29 AM'  '4/10/2022 5:48:55 PM'
        return: the corresponding timestamp
        '''
        time_str = time_in_12_sys[0:-3]
        am_pm_label = time_in_12_sys[-2:]
        formated_time = datetime.strptime(time_str, '%m/%d/%Y %H:%M:%S')
        final_time = formated_time if am_pm_label == 'AM' else (formated_time  + timedelta(hours=12))

        return final_time.timestamp()
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/73094
推荐阅读
相关标签
  

闽ICP备14008679号