Объединение списка в панды данных - PullRequest
0 голосов
/ 08 июня 2018

Я пытаюсь объединить список списка, который состоит из индекса даты, как каждый список, в один кадр данных по оси = 1.Пожалуйста, найдите код ниже:

d=[]
for i in range(0,Alpha.shape[0]-1):
    d.append(pd.date_range(start=Alpha.iloc[i]['Month_year'], end=Alpha.iloc[i+1]['Month_year']-pd.DateOffset(days=1), freq='D'))

Код выше создает индекс серии дат, как показано ниже:

[DatetimeIndex(['2014-04-01', '2014-04-02', '2014-04-03', '2014-04-04',
            '2014-04-05', '2014-04-06', '2014-04-07', '2014-04-08',
            '2014-04-09', '2014-04-10', '2014-04-11', '2014-04-12',
            '2014-04-13', '2014-04-14', '2014-04-15', '2014-04-16',
            '2014-04-17', '2014-04-18', '2014-04-19', '2014-04-20',
            '2014-04-21', '2014-04-22', '2014-04-23', '2014-04-24',
            '2014-04-25', '2014-04-26', '2014-04-27', '2014-04-28',
            '2014-04-29', '2014-04-30'],
           dtype='datetime64[ns]', freq='D'),
DatetimeIndex(['2014-05-01', '2014-05-02', '2014-05-03', '2014-05-04',
            '2014-05-05', '2014-05-06', '2014-05-07', '2014-05-08',
            '2014-05-09', '2014-05-10', '2014-05-11', '2014-05-12',
            '2014-05-13', '2014-05-14', '2014-05-15', '2014-05-16',
            '2014-05-17', '2014-05-18', '2014-05-19', '2014-05-20',
            '2014-05-21', '2014-05-22', '2014-05-23', '2014-05-24',
            '2014-05-25', '2014-05-26', '2014-05-27', '2014-05-28',
            '2014-05-29', '2014-05-30', '2014-05-31'],....

Я хотел объединить список 'd' в фрейм данных,Когда я попробовал следующее,

df=pd.DataFrame()
for i in range(0,len(d)):
    for j in range(0,len(d[i])):
        df.append(d[i][j])

Я получаю следующую ошибку,

TypeError: cannot concatenate object of type "<class 'pandas._libs.tslib.Timestamp'>"; only pd.Series, pd.DataFrame, and pd.Panel (deprecated) objs are valid

Не могли бы вы помочь мне решить эту проблему?Я хочу, чтобы все даты в столбце мудрым образом.

Заранее спасибо

1 Ответ

0 голосов
/ 08 июня 2018

Я думаю, нужно numpy.concatenate:

df = pd.DataFrame(index=np.concatenate(d))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...