我正在使用带有 sqlite 数据库的 SQLObject 来存储文档记录。已扫描文档的文档信息存储在文本文件中。我需要阅读所有这些文本文件(大约 800 个)并从中加载文档记录(每个文件平均 40 个文档)。目前我的代码如下(文档是表格): -
for doc in cc.documents:
print doc['id']
doc_recs = Document.selectBy(costcode = x, doc_id = int(doc['id']))
dcmnt = doc_recs.getOne(None)
if not dcmnt:
dcmnt = Document(costcode = x, doc_id = int(doc['id']))
dcmnt.title = doc['title']
dcmnt.author = doc['author']
dcmnt.recipient = doc['recipient']
dcmnt.date = doc['date']
dcmnt.firstpage = doc['firstpage']
dcmnt.lastpage = doc['lastpage']
dcmnt.type = doc['type']
dcmnt.allpages = doc['allpages']
但这需要很长时间,而且每张唱片都需要更长的时间。
大概每次我更改属性时,SQLObject 都会提交记录,这很浪费。如果我只是添加记录,我可以在首次创建记录的同时创建属性,这应该会更快,但 SQLObjects 在添加记录时似乎仍然很慢。