次のように、構造化データをピクルして ndb.PickleProperty() プロパティにピクル解除しようとしています。
month = MonthRecord.get_or_insert(month_yr_str, parent=ndb.Key('Type','Grocery'), record=pickle.dumps(defaultdict(list_list)))
names_dict = pickle.loads(month.record) # unpickle for updating
# ... # some modifications on names_dict
month.record = pickle.dumps(names_dict) # pickle
month.put() # commit changes
ここで、モデル MonthRecord は次のように定義されます。
class MonthRecord(ndb.Model):
record = ndb.PickleProperty() # {name: [[date&time],[expenses]]}
および list_list として:
def list_list(): # placeholder function needed by pickle at module level
return [[],[]]
最初の実行は正常に機能します (get_or_insert で大文字と小文字の挿入がヒットし、新しい MonthRecord エンティティが作成されます)。ただし、後続の実行中 (つまり、記録される当月内の新しい費用)、次のエラーが発生します。
Traceback (most recent call last):
File "C:\GAE_Projects\qb_lite\fin.py", line 31, in update_db
names_dict = pickle.loads(month.record)
File "C:\Python27\lib\pickle.py", line 1382, in loads
return Unpickler(file).load()
File "C:\Python27\lib\pickle.py", line 858, in load
dispatch[key](self)
File "C:\Python27\lib\pickle.py", line 1133, in load_reduce
value = func(*args)
TypeError: __init__() takes exactly 4 arguments (1 given)
エラーの原因に関するアイデアはありますか?