使用Python中的“for循环”将预测结果写入每个组的单独文件中

2024-09-29 23:20:01 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个数据帧“c”,它有一个名为“UNITID”的属性。我已经根据不同的“UNITID”划分了数据帧,并在每个“UNITID”上运行了神经网络模型。请参见下面的代码。我使用枚举函数将它们标记为c1、c2、…cn,并存储在“c_new”中

c_count = c['UNITID'].nunique()
c_new={"c{0}".format(i+1):j[1]for i,j in enumerate(c.groupby('UNITID'))}
for i in range(c_count):
    i = i+1
    c_data = 'c'+str(i)
    print("==============================-------{}-------===========================".format(i))
    c_new[c_data] = c_new[c_data].set_index('DATETIME')
    values = c_new[c_data].values
    # Encoding categorical data
    ..
    #Convert Categories in Text into numbers using Label encoder/ OneHotEncoding
    ..
    # split into train and test sets
    ..
    # reshape input to be 3D [samples, timesteps, features]
    ..
    #Scale and Normalize inputs
    ..
    # Deep Neural Network model
    ..
    # fit network
    ..
    # make a prediction
    ..

    #performance metrics: MAE, MSE, RMSE, Rsq
    ... 

每次为每个UNITID运行模型时,都会生成新的预测结果,但我当前的代码只会将结果覆盖到具有相同文件名的相同文件中(有意义,因为df.to_csv就是这样工作的)

我想要的是每次生成新结果时将结果写入一个单独的文件。对于每个c{i},其中i=1,2。。N每个的预测输出文件应该是c_out_{i},如下所示

i/p file --> o/p

c1 --> c_out_1
c2 --> c_out_2
c3 --> c_out_3
.
.
cn --> c_out_n

我怎样才能做到这一点

#Write  predictions to file
test_y = pd.DataFrame(test_y) #Actual values
yhat = pd.DataFrame(yhat) #predicted values using the model

test_y.rename(columns= {0: 'Actual value'}, inplace = True)
yhat.rename(columns = {0: 'Pred value'}, inplace = True)

new = pd.concat([test_y, yhat], axis = 1)
#print(('ct'+ str(i)))
new.to_csv('c_out_{i}.csv') #I want to write a different output csv file for each UNITD's prediction; 

任何帮助都将不胜感激。谢谢


Tags: 文件csvto数据intestnewfor

热门问题