m0_50222467 2020-09-14 15:40 采纳率: 0%
浏览 513

Python中dataframe的日期转换成常数

各位大佬们,现在我处理了一个dataframe,里面时间的格式是YYYY-MM-DD,现在想把这些日期按时间顺序转换成常数以便后续计算等,一样的日期则转换的数字是一样的。求助怎么转换。

这是目前的dataframe的格式

         id           time     
0       a     2015-10-29 
1       b     2015-10-29  
2       c     2017-11-01 
3       d     2018-10-01
4       e     2018-10-06
5       f     2018-10-06

我想要的转换结果是:

         id           time     
0       a               1 
1       b               1  
2       c               2 
3       d               3
4       e               4
5       f               4
  • 写回答

1条回答 默认 最新

  • threenewbee 2020-09-14 16:28
    关注
    这个可以考虑计算日期到某一天的天数的差来作为这个常数。
    比如通常时间戳使用当前的时间到1970年1月1日(选这一天的目的是一般情况,不会有更早的日期,所以可以让结果为正数)的时间差,因为你只要日期,不用考虑时间,
    
    from datetime import datetime
    def getdtconst(dt):
      basedt = datetime(1970, 1, 1)
      return (dt - basedt).days
    
    n = getdtconst(datetime(2015,10, 29))
    print(n)
    
    
    评论

报告相同问题?

悬赏问题

  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能