gpt4 book ai didi

python - 如何在每次迭代中根据索引替换列值。以便每个表在每次迭代中都有新的值集

转载 作者:行者123 更新时间:2023-12-01 09:17:26 24 4
gpt4 key购买 nike

谁能帮我解决这个问题。

   Index      word
0 0 I
1 1 am
2 2 so
3 3 good
4 4 and
5 5 smart

df_series=[]
for d in range(0,2):
df_series.append(df)

def pos(x):
position=[]
for u in x:
position.append(np.random.choice(u[0]))
return position

two = [5,2]
j = [1,0]
df1=[]
df1.append(pd.DataFrame(two))
df1.append(pd.DataFrame(j))

df1

   0
0 5
1 2
0
0 1
1 0

final=[]
L=['NA','****']
for eachtable in df_series:
# print(eachtable)
eachtable.loc[pos(df1),'word'] = random.choice(L)
final.append(eachtable)

最终

 Index  word
0 ****
1 NA
2 so
3 good
4 and
5 NA

Index word
0 ****
1 NA
2 so
3 good
4 and
5 NA

到目前为止,我只得到这样的结果。位置仅针对第一个表进行更改,并为所有迭代重复相同的位置。我想更改每次迭代的位置。任何人都可以找到我的代码中的错误并帮助我解决这个问题。

我想要这样的东西

打印(最终)

Index   word
0 ****
1 NA
2 so
3 good
4 and
5 NA
Index word
0 I
1 am
2 ****
3 good
4 NA
5 smart

最佳答案

问题出现在第一个循环中,列表中仍然引用相同的DataFrame(Series):

for eachtable in df_series:
print (id(eachtable))
294921776
294921776

解决方案是添加 copy :

df_series=[]
for d in range(0,2):
df_series.append(df.copy())

检查:

for eachtable in df_series:
print (id(eachtable))
294987928
294922056

for eachtable in df_series:
eachtable.loc[pos(df1),'word'] = random.choice(L)
final.append(eachtable)

print (final)
[ Index word
0 0 NA
1 1 am
2 2 NA
3 3 good
4 4 and
5 5 smart, Index word
0 0 I
1 1 ****
2 2 so
3 3 good
4 4 and
5 5 ****]

关于python - 如何在每次迭代中根据索引替换列值。以便每个表在每次迭代中都有新的值集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51114817/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com