Индексирование через фрейм данных Pandas с отметкой времени и даты - PullRequest
0 голосов
/ 08 ноября 2019
   >>> df1
                    AAPL       GOOG 

    Date                                                      
    2016-03-01  0.013422  -0.321900
    2016-03-02 -0.012341  -0.000800 
    2016-03-03 -0.000772   0.055500
    2016-03-07 -0.413103  -0.009555

   >>> df2
                        NFLX         FB 
        Date                                                      
        2016-03-01  0.013422  -0.321900
        2016-03-02 -0.012341  -0.000800 
        2016-03-03 -0.000772   0.055500
        2016-03-07 -0.413103  -0.009555

Я хочу иметь возможность индексировать по временным меткам. Но это дает мне ошибку. Например, если я хочу сделать:

df1['2016-03-01'] 

, это работает и возвращает первую строку df1. Но если я сделаю:

df1[df2.index[0]]

Это не работает и возвращает и ошибка. Я кодирую что-то, что повторяет даты, и я изо всех сил пытаюсь найти решение. Пожалуйста, помогите

1 Ответ

1 голос
/ 08 ноября 2019

Make your dfs

df1 = pd.DataFrame({"Date": ["2016-03-01","2016-03-02","2016-03-03","2016-03-07"],
                   "AAPL": [0.013422,-0.012341,-0.000772,-0.413103],
                   "GOOG": [-0.321900,-0.000800,0.055500,-0.009555]})

df2 = pd.DataFrame({"Date": ["2016-03-18"],
                    "NFLX": [0.23525],
                    "FB": [-0.28942]})

# set date to datetime
df1["Date"],df2["Date"] = pd.to_datetime(df1["Date"]),pd.to_datetime(df2["Date"])

# set Date as index
df1,df2 = df1.set_index("Date"),df2.set_index("Date")

# output1
>>> df1
                AAPL       GOOG 

Date                                                      
2016-03-01  0.013422  -0.321900
2016-03-02 -0.012341  -0.000800 
2016-03-03 -0.000772   0.055500
2016-03-07 -0.413103  -0.009555

# output2
>>> df2
                NFLX       FB 

Date        
2016-03-01  0.235250    -0.289420

Добавление строк по индексу от df2 до df1

for i,j in enumerate(df1.index):
    df2 = df2.append(df1.iloc[[i]],sort=True)

>>> df2
             AAPL       FB      GOOG      NFLX
Date                
2016-03-18  NaN     -0.28942    NaN     0.23525
2016-03-01  0.013422    NaN     -0.321900   NaN
2016-03-02  -0.012341   NaN     -0.000800   NaN
2016-03-03  -0.000772   NaN     0.055500    NaN
2016-03-07  -0.413103   NaN     -0.009555   NaN
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...