将日期类型转换为int类型
因工作需要最近刚刚接触pandas,水平较菜,工作中总是遇到一些问题,在此记录一下。如有错误欢迎指正。
最近因工作需要总是会遇到pandas中的一些类型转换,一些简单的类型转换可以解决,但是遇到日期类型就有点蒙了,在网上找了一些方法,在此记录一下。
问题描述:
1.将日期类型的数据转换为int类型,例如:数据为 2022-08-23 转换为int类型 20220823
2.如果有空值,则将空值替换为 99991231
解决方法:
方法一、
# self.deal_df['end_date'] = self.deal_df['end_date'].astype(str) # 先将日期类型转换为字符串类型
# 判断字符串中是否有空值 x.__contains__('NaT') or x.__contains__('nan')
# self.deal_df['end_date'] = self.deal_df['end_date'].apply(lambda x: '99991231' if x.__contains__('NaT') or x.__contains__('nan') else self.time_to_str(x)).astype(str)
# 将字符串转换为int类型
# self.deal_df['end_date'] = self.deal_df['end_date'].astype(int)
方法二、
self.deal_df['end_date'] = self.deal_df['end_date'].apply(lambda x: 99991231 if pd.isnull(x) else int(x.strftime('%Y%m%d')))