Puoi trasporre il dataframe a riga singola (che risulta comunque in un dataframe) e quindi comprimere i risultati in una serie (l'inverso di to_frame
).
df = pd.DataFrame([list(range(5))], columns=["a{}".format(i) for i in range(5)])
>>> df.T.squeeze()
a0 0
a1 1
a2 2
a3 3
a4 4
Name: 0, dtype: int64
Nota: per accogliere il punto sollevato da @IanS (anche se non è nella domanda dell'OP), verifica la dimensione del dataframe. df
Suppongo che sia un dataframe, ma i casi limite sono un dataframe vuoto, un dataframe di forma (1, 1) e un dataframe con più di una riga, nel qual caso l'uso dovrebbe implementare la funzionalità desiderata.
if df.empty:
result = pd.Series()
elif df.shape == (1, 1)
result = pd.Series(df.iat[0, 0], index=df.columns)
elif len(df) == 1:
result = df.T.squeeze()
else:
pass
Questo può anche essere semplificato sulla falsariga della risposta fornita da @themachinist.
if len(df) > 1:
pass
else:
result = pd.Series() if df.empty else df.iloc[0, :]
df.T