Я пытаюсь переделать рамку данных pandas из длинного в широкий формат, а временные метки теряют часовой пояс.Pandas длинный до широкого без потери осведомленности о часовом поясе
Вот воспроизводимый пример:
import pandas as pd
long = pd.DataFrame(dict(
ind=[1,1,2, 2],
events=['event1', 'event2', 'event1', 'event2'],
time=[pd.Timestamp('2015-03-30 00:00:00', tz='UTC'),
pd.Timestamp('2015-03-30 01:00:00', tz='UTC'),
pd.Timestamp('2015-03-30 02:00:00', tz='UTC'),
pd.Timestamp('2015-03-30 03:00:00', tz='UTC')]))
Тогда при взгляде на long.time
я получаю часовой пояс-Aware Серию.
0 2015-03-30 00:00:00+00:00
1 2015-03-30 01:00:00+00:00
2 2015-03-30 02:00:00+00:00
3 2015-03-30 03:00:00+00:00
Name: time, dtype: datetime64[ns, UTC]
и после изменения формы как этот
wide = long.set_index(['ind'] + ['events']).unstack(level=1).reset_index()
часовой пояс, уходит. Например. wide.time.event1
0 2015-03-30 00:00:00
1 2015-03-30 02:00:00
Name: event1, dtype: datetime64[ns]
Есть еще один способ изменения формы, что не теряет часовой пояс?
Любой обходной путь, который вам с подскажите? – kael
@kael up post – piRSquared