以下问题。
我有一个格式如下的数据框。
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和堆栈溢出做了一些深入的研究,但似乎没有适合这个问题的解决方案。
一如既往,我们非常感谢任何帮助。
答案 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