python3中的日期时间到十进制小时和分钟

Posted

技术标签:

【中文标题】python3中的日期时间到十进制小时和分钟【英文标题】:datetime to decimal hour and minutes in python3 【发布时间】:2018-08-06 03:54:17 【问题描述】:

我有一个dataframe,每个30 minutes 都有meteorological 数据。使用我的日期时间索引,我需要创建一个带有timestamps 的列,但它必须在decimal 中。下面是一个例子:

In [134]: df.index[0:3]
Out[134]: 
DatetimeIndex(['2016-01-01 00:30:00', '2016-01-01 01:00:00',
               '2016-01-01 01:30:00'],
              dtype='datetime64[ns]', name='date_time', freq=None)

我需要创建一个列如下:

df.new[0:3]
0.5,1,1.5

我在.5 中转换了 30 分钟。 按照我的脚本:

import pandas as pd
import numpy as np
df = pd.read_csv('./cs_teste_full_output_2018-02-26T004329_adv.csv',skiprows=(0),
                 header=1,na_values='-9999.0')
df = df.drop(df.index[[0]])
df['date_time'] = df['date'] + str(' ') + df['time']
df = df.set_index(pd.DatetimeIndex(df['date_time']))


df.index.strftime('%M')/60

for i in range(1,len(df.index),1):
    print(i)
    df['minute'][i] = np.array(list(map(int,list(df.index.strftime('%M')))))/60
    df['hour'] = df.index.strftime('%H')
    df['hour_minute'] = df['hour'] + df['minute']

但是这种方式是行不通的,我不能以任何其他方式做到这一点。

【问题讨论】:

【参考方案1】:

一种方法是提取小时并将分钟转换为小时。

应该不需要从字符串转换为/。

import pandas as pd

idx = pd.DatetimeIndex(['2016-01-01 00:30:00',
                        '2016-01-01 01:00:00',
                        '2016-01-01 01:30:00'],
                       dtype='datetime64[ns]', name='date_time', freq=None)

idx.hour + idx.minute / 60

# Float64Index([0.5, 1.0, 1.5], dtype='float64', name='date_time')

【讨论】:

非常好的解决方案 ;)

以上是关于python3中的日期时间到十进制小时和分钟的主要内容,如果未能解决你的问题,请参考以下文章

如何在 SQL 中的日期时间列中添加小时、分钟和秒?

Oracle DB 中的日期时间格式不正确,转换为小时和分钟

如何在一步Excel-VBA中删除日期中的小时和分钟

根据 R 中的日期和小时以 15 分钟的间隔聚合数据

NSdate(时区)中的问题日期时间显示过去 5 小时 30 分钟

将纪元时间转换为小时前,从 iPhone 中的当前日期开始分钟前