我正在尝试通过管道运行几个数据帧以永久更改每个数据帧,但是更改不会在for循环之外持久存在。有人可以告诉我正确的语法来做到这一点吗?所有编辑都像edit_1g()那样分配并返回一个数据框。谢谢。
# create pipeline to preprocess the data:
def pipeline_1(df):
df1=(df.pipe(edit_2a)
.pipe(edit_2b)
.pipe(edit_2d)
.pipe(edit_2e)
.pipe(edit_1f)
.pipe(edit_1j)
.pipe(edit_1g)
.pipe(edit_2h)
)
return df1
# list the data frames we want to run through our pipeline:
dfs = {'df_orders':df_orders, 'df_accts_summary':df_accts_summary, 'df_accts1':df_accts1,
'df_traders_summary':df_traders_summary, 'df_traders1':df_traders1,
'df_tag76_summary':df_tag76_summary, 'df_tag761':df_tag761}
print('data frames altered via pipeline_1: \n')
for key, values in dfs.items():
values = pipeline_1(values) # changes aren't persisting outside of the loop
print(key + ' ' + str(values.shape))
# round the decimals of columns:
def edit_1g(df):
d = {'icpwp10bp':0, 'icpwp2bp':0, 'icslippagebpbp':0, 'participationrate':0, 'adv':1, 'twodprioris':0,
'twodpostis':0, 'orderval':0, 'valuedark':0, 'mktvalflt':0, 'numberoffills': 0, 'size':0,
'lmtadjintvwap':0, 'fivedsprd':0, 'tendvol':0
}
df = df.round(d)
return df
答案 0 :(得分:2)
我想最后一部分有问题:
for key, values in dfs.items():
values = pipeline_1(values)
print(key + ' ' + str(values.shape))
您应该在这里分配:
new_dfs = dict()
for key, values in dfs.items():
values = pipeline_1(values)
new_dfs[key] = values
print(key + ' ' + str(values.shape))
因此,new_dfs
包含新的数据帧。但是这种方法将复制您的数据。您可以尝试分配就地,
for key, values in dfs.items():
values = pipeline_1(values)
dfs[key] = values
print(key + ' ' + str(values.shape))