使用python

时间:2017-07-03 04:34:36

标签: python pandas dataframe

以下问题。

我有一个格式如下的数据框。

   Col1 Col2 Col3 Col4  
1    0    0    0    0
2    0    0    0    0

此外,我有一个与列名匹配的值列表:

ColNameList1 = [Col1, Col3] #list for the first row
ColNameList2 = [Col3, Col4] #list for the second row

目标是将每个列匹配的值0更改为1。

    Col1 Col2 Col3 Col4  
1    1    0    1    0 
2    0    0    1    1

我对Pandas文档以及google和堆栈溢出做了一些深入的研究,但似乎没有适合这个问题的解决方案。

一如既往,我们非常感谢任何帮助。

1 个答案:

答案 0 :(得分:9)

您只需使用loc和设置值:

df.loc[1,ColNameList1]=1

df.loc[2,ColNameList2]=1

df
Out[10]: 
   Col1  Col2  Col3  Col4
1     1     0     1     0
2     0     0     1     1