使用Python和bsddb3在Berkeley DB数据库中存储数据

时间:2015-09-28 22:03:34

标签: python python-3.x berkeley-db bsddb

我正在尝试使用Python 3.5和bsddb3将数据写入Berkeley DB数据库。我对Berkeley DB没有任何经验,但我喜欢使用时间戳作为键,并使用一些JSON数据作为相应的值。以下示例导致错误:

#!/usr/bin/env python3

import bsddb3
import time

fn = 'berkeley.db'
db = bsddb3.hashopen(fn, 'c')
t = time.time()
d = "{ data: 'foo' }"
db[t] = d
db.close()

错误:

$ python3 example.py
[...]
self.db[key] = value
TypeError: Bytes or Integer object expected for key, float found

使用整数而不是time.time(),例如db[0] = data,也不起作用:TypeError: Integer keys only allowed for Recno and Queue DB's

不幸的是,没有关于如何在Python中使用Berkeley DB的全面文档。关于我做错了什么的任何建议?

1 个答案:

答案 0 :(得分:1)

我在阅读documentation of Kyoto Cabinet时得到了解决方案。密钥必须编码为byte:

db[b'key'] = d
print((db.get(b'key')))

运行上述更改的示例将导致存储数据集的输出:

$ python3 main.py
b"{ data: 'random' }"