Neudefinition des Index in einem Pandas DataFrame-Objekt

83

Ich versuche, ein Pandas- DataFrameObjekt wie folgt neu zu indizieren.

From:
            a   b   c
        0   1   2   3
        1  10  11  12
        2  20  21  22

To :
           b   c
       1   2   3
      10  11  12
      20  21  22

Ich gehe wie unten gezeigt vor und erhalte die falsche Antwort. Irgendwelche Hinweise, wie das geht?

>>> col = ['a','b','c']
>>> data = DataFrame([[1,2,3],[10,11,12],[20,21,22]],columns=col)
>>> data
    a   b   c
0   1   2   3
1  10  11  12
2  20  21  22
>>> idx2 = data.a.values
>>> idx2
array([ 1, 10, 20], dtype=int64)
>>> data2 = DataFrame(data,index=idx2,columns=col[1:])
>>> data2
     b   c
1   11  12
10 NaN NaN
20 NaN NaN

Irgendeine Idee, warum das passiert?

Nitin
quelle
1
Da Sie den ersten DF verwenden, um den zweiten zu erstellen, werden nur die Zeilen abgerufen, in denen idx2 den data.index schneidet, d. h. Reihe 1
RuiDC

Antworten:

187

Warum benutzt du nicht einfach die set_indexMethode?

In : col = ['a','b','c']

In : data = DataFrame([[1,2,3],[10,11,12],[20,21,22]],columns=col)

In : data
Out:
    a   b   c
0   1   2   3
1  10  11  12
2  20  21  22

In : data2 = data.set_index('a')

In : data2
Out:
     b   c
a
1    2   3
10  11  12
20  21  22
Avaris
quelle
17
Um den Indexnamen wie im ursprünglichen Beispiel zu entfernen: data2.index.name = None
Daniele
5

Wenn Sie kein 'a' im Index haben möchten

Im :

col = ['a','b','c']

data = DataFrame([[1,2,3],[10,11,12],[20,21,22]],columns=col)

data

Aus:

    a   b   c
0   1   2   3
1  10  11  12
2  20  21  22

Im :

data2 = data.set_index('a')

Aus:

     b   c
a
1    2   3
10  11  12
20  21  22

Im :

data2.index.name = None

Aus:

     b   c
 1   2   3
10  11  12
20  21  22
Aakash Saxena
quelle
1
Das zweite Out ist nicht korrekt. Es gibt noch eine unbenannte Spalte auf der linken Seite, die 0, 1, 2 enthält.
Yster