1

我有一个 pandas 数据框列,其中填充了 100 个国家/地区的国家/地区代码。我想用这些来做回归,但我只想在我的数据集中为特定国家创建虚拟变量。

我认为这会起作用:

dummies = pd.get_dummies(df.CountryCode, prefix='cc_')
df_and_dummies = pd.concat([df,dummies[dummies['cc_US', 'cc_GB']]], axis=1)
df_and_dummies

但这给了我错误:

KeyError: ('cc_US', 'cc_GB')

我的数据框目前看起来像:

dframe = pd.DataFrame({'A': ['a', 'b', 'a'], 'B': ['b', 'a', 'c'],
                'CountryCode': ['UK', 'US', 'RU']})
dframe

没有假人

但我希望它看起来像这样:

带有虚拟变量

是否有一种简单的方法来指定您希望在get_dummies方法中包含哪些值,或者是否有另一种方法来识别特定的虚拟变量?

4

1 回答 1

1

假人看起来像这样:

In [25]: dummies
Out[25]:
   cc_RU  cc_UK  cc_US
0      0      1      0
1      0      0      1
2      1      0      0

要选择其中的某些列,您可以在 [] getitem 中提供列名列表:

In [27]: dummies[['cc_US', 'cc_UK']]
Out[27]:
   cc_US  cc_UK
0      0      1
1      1      0
2      0      0

所以你实际上错过了一个 [ 括号。
完整的代码就变成了:

In [29]: pd.concat([df, dummies[['cc_US', 'cc_UK']]], axis=1)
Out[29]:
   A  B CountryCode  cc_US  cc_UK
0  a  b          UK      0      1
1  b  a          US      1      0
2  a  c          RU      0      0
于 2015-10-01T22:23:36.633 回答