簡體   English   中英

在一行中分配一行pandas DataFrame中的多個列值

[英]Assigning multiple column values in a single row of pandas DataFrame, in one line

我正在嘗試為 DataFrame 中的一行分配多個值,我需要正確的語法。

請參閱下面的代碼。

import pandas as pd

df = pd.DataFrame({
'A': range(10),
'B' : '',
'C' : 0.0,
'D' : 0.0,
'E': 0.0,
})

#Works fine
df['A'][2] = 'tst'

#Is there a way to assign multiple values in a single line and if so what is the correct syntax
df[['A', 'B', 'C', 'D', 'E']][3] = ['V1', 4.3, 2.2, 2.2, 20.2]

謝謝您的幫助

使用loc (並避免鏈接):

In [11]: df.loc[3] = ['V1', 4.3, 2.2, 2.2, 20.2]

這確保分配是在 DataFrame 上就地完成,而不是在副本(和垃圾收集)上完成。

您只能指定某些列:

 In [12]: df.loc[3, list('ABCDE')] = ['V1', 4.3, 2.2, 2.2, 20.2]

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM