python 处理常用的时间问题

这篇博客介绍了如何在Python中将字符串时间转换为日期时间格式,包括获取年月日时分秒的方法。还展示了时间戳与字符串时间之间的转换,并提供了获取当前日期和时间的示例。此外,讲解了如何根据当前日期推算前N天的日期,以及在数据操作中应用这些技巧进行数据筛选。
摘要由CSDN通过智能技术生成
  1. 如何将字符串的时间转转为时间格式的数据
# 变成年月日时分秒
XJ = pd.to_datetime(data_dd["新建时间"], format="%Y/%m/%d %H:%M:%S")
def getMonth(time):  # 获取月份
           a = (time.dt.month.astype(float)).tolist()
           return a
def getDay(time):  # 获取日
          a = (time.dt.day.astype(float)).tolist()
          return a
def getHoure(time):  # 获取小时
           a = (time.dt.hour.astype(float)).tolist()
           return a
def getMinute(time):  # 获取分钟数
          a = (time.dt.minute.astype(float)).tolist()
          return a
def getYear(time):
           a = (time.dt.year.astype(float)).tolist()
           return a
train["month"] = getMonth(Ptakeoff)
train["day"] = getDay(Ptakeoff)
train['year'] = getYear(Ptakeoff)


# 变成年月日
data1['时间'] = pd.to_datetime(data1['时间'], errors='coerce')
data1['时间'] = data1['时间'].dt.normalize()

data1['year'] = data1['时间'].dt.year
a = data1['时间'].dt.month
data1["month"]=a
data1['day'] = data1['时间'].dt.dayofyear
data1['weekday'] = data1['时间'].dt.weekday  # 0-6
  1. 字符串时间类型与时间戳之间互转
#设a为字符串
import time
a = "2011-09-28 10:00:00"

#中间过程,一般都需要将字符串转化为时间数组
time.strptime(a,'%Y-%m-%d %H:%M:%S')
>>time.struct_time(tm_year=2011, tm_mon=9, tm_mday=27, tm_hour=10, tm_min=50, tm_sec=0, tm_wday=1, tm_yday=270, tm_isdst=-1)

#将"2011-09-28 10:00:00"转化为时间戳
time.mktime(time.strptime(a,'%Y-%m-%d %H:%M:%S'))
>>1317091800.0

#将时间戳转化为localtime
x = time.localtime(1317091800.0)
time.strftime('%Y-%m-%d %H:%M:%S',x)

#获取当前日期
time.strftime("%Y-%m-%d")
>>>'2015-03-13'

#获取当前时间
time.strftime("%Y-%m-%d %H:%M:%S")
>>>'2015-03-13 20:26:22'
  1. 根据目前日期推前N天的日期
import datetime as DT
today = DT.date.today()
week_ago = today - DT.timedelta(days=7)
》》  datetime.date(2022, 8, 15)

# 但是若today是时间戳格式(上面1中的(#变成年月日)),则week_ago 也会是时间戳格式
import datetime as DT
today = data_ydhc_sj['日期'].tolist()[-1]
week_ago = today - DT.timedelta(days=7)
week_ago
》》Timestamp('2022-08-14 00:00:00')

# 后续就可以根据该日期机进行数据筛选
data_ydhc_sj1=data_ydhc_sj[(data_ydhc_sj['分公司']==FFGS)&(data_ydhc_sj['日期']==week_ago)]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值