gpt4 book ai didi

python - 在两个不同的文件中转储和加载 dill ( pickle )

转载 作者:行者123 更新时间:2023-12-05 08:19:02 28 4
gpt4 key购买 nike

我认为这对许多知道如何处理 pickle 的人来说是最基本的。但是,尝试了几个小时后,我仍然无法完全正确。我有以下代码:

在第一个文件中

import pandas as pd

names = ["John", "Mary", "Mary", "Suzanne", "John", "Suzanne"]
scores = [80, 90, 90, 92, 95, 100]

records = pd.DataFrame({"name": names, "score": scores})
means = records.groupby('name').mean()

def name_score_function(record):
if record in names:
return(means.loc[record, 'score'])

import dill as pickle
with open('name_model.pkl', 'wb') as file:
pickle.dump(means, file)

第二个文件

我想加载第一个文件中的内容,并通过函数 name_model(record) 调用一个人(即 John、Mary、Suzanne)的分数:

import dill as pickle
B = pickle.load('name_model.pkl')

def name_model(record):
if record in names:
return(means.loc[record, 'score'])

这里显示错误:

File "names.py", line 21, in <module>
B = pickle.load('name_model.pkl')
File "/opt/conda/lib/python2.7/site-packages/dill/dill.py", line 197, in load
pik = Unpickler(file)
File "/opt/conda/lib/python2.7/site-packages/dill/dill.py", line 356, in __init__
StockUnpickler.__init__(self, *args, **kwds)
File "/opt/conda/lib/python2.7/pickle.py", line 847, in __init__
self.readline = file.readline
AttributeError: 'str' object has no attribute 'readline'

我知道这个错误是因为我对 pickle 缺乏了解。我会虚心接受您的意见来改进此代码。谢谢!!

更新我想实现的更具体的事情:

我希望能够使用我在第一个文件中编写的函数并将其转储,然后在第二个文件中读取它并能够使用此函数查询记录中任何人的平均分数.

这是我的:

import pandas as pd

names = ["John", "Mary", "Mary", "Suzanne", "John", "Suzanne"]
scores = [80, 90, 90, 92, 95, 100]

records = pd.DataFrame({"name": names, "score": scores})
means = records.groupby('name').mean()

def name_score_function(record):
if record in names:
return(means.loc[record, 'score'])

B = name_score_function(record)

import dill as pickle
with open('name_model.pkl', 'wb') as file:
pickle.dump(B, file)

with open('name_model.pkl', 'rb') as file:
B = pickle.load(f)

def name_model(record):
return B(record)

print(name_model("John"))

当我执行这段代码时,出现了这个错误 File "test.py", line 13, in <module>
B = name_score_function(record)
NameError: name 'record' is not defined

非常感谢您的协助和耐心等待。

最佳答案

谢谢。看起来下面可以解决问题。

import pandas as pd

names = ["John", "Mary", "Mary", "Suzanne", "John", "Suzanne"]
scores = [80, 90, 90, 92, 95, 100]

records = pd.DataFrame({"name": names, "score": scores})
means = records.groupby('name').mean()

import dill as pickle
with open('name_model.pkl', 'wb') as file:
pickle.dump(means, file)

with open('name_model.pkl', 'rb') as file:
B = pickle.load(file)

def name_score_function(record):
if record in names:
return(means.loc[record, 'score'])

print(name_score_function("John"))

关于python - 在两个不同的文件中转储和加载 dill ( pickle ),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38447815/

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