Python: добавление часов в метку времени pandas
Я читаю csv-файл в фрейм данных pandas df
и получаю следующее:
df.columns
Index([u'TDate', u'Hour', u'SPP'], dtype='object')
>>> type(df['TDate'][0])
<class 'pandas.tslib.Timestamp'>
type(df['Hour'][0])
<type 'numpy.int64'>
>>> type(df['TradingDate'])
<class 'pandas.core.series.Series'>
>>> type(df['Hour'])
<class 'pandas.core.series.Series'>
Оба столбца Hour
и TDate
имеют 100 элементов. Я хочу добавить соответствующие элементы часа к TDate.
Я попробовал следующее:
import pandas as pd
from datetime import date, timedelta as td
z3 = pd.DatetimeIndex(df['TDate']).to_pydatetime() + td(hours = df['Hour'])
Но я получаю ошибку, так как кажется, что td не принимает массив в качестве аргумента. Как добавить каждый элемент Hour
к соответствующему элементу TDate
.
1 ответ:
Я думаю, что вы можете добавить в столбец
TDate
столбецHour
преобразованныйto_timedelta
сunit='h'
:df = pd.DataFrame({'TDate':['2005-01-03','2005-01-04','2005-01-05'], 'Hour':[4,5,6]}) df['TDate'] = pd.to_datetime(df.TDate) print (df) Hour TDate 0 4 2005-01-03 1 5 2005-01-04 2 6 2005-01-05 df['TDate'] += pd.to_timedelta(df.Hour, unit='h') print (df) Hour TDate 0 4 2005-01-03 04:00:00 1 5 2005-01-04 05:00:00 2 6 2005-01-05 06:00:00