Целочисленный в Python буфер только для чтения - PullRequest
2 голосов
/ 01 декабря 2009

Я использую CDB для постоянной базы данных в Python. Я хотел бы связать целочисленные идентификаторы с некоторыми строками, и я хотел бы избежать хранения каждого из этих целочисленных идентификаторов в виде строк, а вместо этого сохранить их как целое число. cdb ищет строку или буфер только для чтения. Есть ли способ хранить эти ключи как целые числа вместо строк?

Например:

cdb = cdb.cdbmake("test.cdb","test.cdb.tmp")
key = 5
value = "some test string"

#this throws an error
maker.add(key,value)
#TypeError: add() argument 1 must be string or read-only buffer, not int

#this would work, but seems inefficient
maker.add(str(key),value)

1 Ответ

4 голосов
/ 01 декабря 2009

Согласно веб-сайту cdb база данных принимает в качестве ключей только строки

CDB - это ассоциативный массив: он отображает строки (ключи) в строки (данные).

Так что вам нужно сначала преобразовать целые числа в строки. Я предлагаю вам обернуть str в служебную функцию и забыть о накладных расходах.

...