【问题标题】:Convert string to timedelta in pandas在熊猫中将字符串转换为timedelta
【发布时间】:2019-05-01 18:06:59
【问题描述】:

我有一个时间戳格式为HHHHH:MM的系列:

timestamp = pd.Series(['34:23', '125:26', '15234:52'], index=index)

我想将其转换为 timedelta 系列。

现在我设法在单个字符串上做到这一点:

str[:-3]
str[-2:]
timedelta(hours=int(str[:-3]),minutes=int(str[-2:]))

如果可能的话,我想以更简洁的方式将它应用到整个系列中。有没有办法做到这一点?

【问题讨论】:

    标签: python pandas string series timedelta


    【解决方案1】:

    您可以使用按列排列的 Pandas 方法:

    s = pd.Series(['34:23','125:26','15234:52'])
    
    v = s.str.split(':', expand=True).astype(int)
    s = pd.to_timedelta(v[0], unit='h') + pd.to_timedelta(v[1], unit='m')
    
    print(s)
    
    0     1 days 10:23:00
    1     5 days 05:26:00
    2   634 days 18:52:00
    dtype: timedelta64[ns]
    

    正如 cmets 中指出的,这也可以在一行中实现,尽管不太清楚:

    s = pd.to_timedelta((s.str.split(':', expand=True).astype(int) * (60, 1)).sum(axis=1), unit='min')
    

    【讨论】:

    • 一行:pd.to_timedelta((s.str.split(':', expand=True).astype(int) * (60, 1)).sum(axis=1), unit='min')
    【解决方案2】:

    我会这样做:

    timestamp = pd.Series(['34:23','125:26','15234:52'])
    x = timestamp.str.split(":").apply(lambda x: int(x[0])*60 + int(x[1]))
    timestamp = pd.to_timedelta(x, unit='s')
    

    【讨论】:

    • 我喜欢@jpp 使用的expand=True 参数。
    【解决方案3】:

    像这样以秒为单位将增量解析为pd.to_timedelta 的参数,

    In [1]: import pandas as pd
    In [2]: ts = pd.Series(['34:23','125:26','15234:52'])
    In [3]: secs = 60 * ts.apply(lambda x: 60*int(x[:-3]) + int(x[-2:]))
    In [4]: pd.to_timedelta(secs, 's')
    Out[4]:
    0     1 days 10:23:00
    1     5 days 05:26:00
    2   634 days 18:52:00
    dtype: timedelta64[ns]
    

    编辑:错过了 ercyp 的答案,该答案也可以,但您需要将 pd.to_timedelta 的参数乘以 60,因为如果我没记错的话,除了对前一小时取模外,分钟不能作为经过时间的度量。

    【讨论】:

      【解决方案4】:

      你可以使用pandas.Series.apply,即:

      def convert(args):
          return timedelta(hours=int(args[:-3]),minutes=int(args[-2:]))
      s = pd.Series(['34:23','125:26','15234:52'])
      s = s.apply(convert)
      

      【讨论】:

        猜你喜欢
        • 2016-05-25
        • 1970-01-01
        • 2021-09-19
        • 1970-01-01
        • 2017-07-31
        • 1970-01-01
        • 2021-02-17
        • 2015-02-06
        • 2017-08-02
        相关资源
        最近更新 更多