dbm
— Interfaces para “banco de dados” Unix¶
Código-fonte: Lib/dbm/__init__.py
dbm
é uma interface genérica para variantes do banco de dados DBM:
Se nenhum desses módulos estiverem instalados, a implementação lenta, mas simples, no módulo dbm.dumb
será usada. Há uma interface de terceiros para o Oracle Berkeley DB.
- exception dbm.error¶
Uma tupla contendo as exceções que podem ser levantadas por cada um dos módulos suportados, com a única exceção também chamada
dbm.error
como o primeiro item — o último é usado quandodbm.error
é levantada.
- dbm.whichdb(filename)¶
Esta função tenta adivinhar qual dos vários módulos de banco de dados simples disponíveis —
dbm.sqlite3
,dbm.gnu
,dbm.ndbm
oudbm.dumb
— deve ser usado para abrir o arquivo fornecido.Retorna um dos seguintes valores:
None
se o arquivo não puder ser aberto porque está ilegível ou não existea string vazia (
''
) se o formato do arquivo não puder ser adivinhadouma string contendo o nome do módulo necessário, tal como
'dbm.ndbm'
ou'dbm.gnu'
Alterado na versão 3.11: filename aceita um objeto caminho ou similar.
- dbm.open(file, flag='r', mode=0o666)¶
Abre um banco de dados e retorna o objeto banco de dados correspondendo.
- Parâmetros:
file (path-like object) – O arquivo de banco de dados para abrir. Se o arquivo de banco de dados já existe, a função
whichdb()
é usada para determinar seu tipo e o módulo apropriado é usado; se ele não existir, o primeiro submódulo listado acima que pode ser importado é usado.flag (str) –
'r'
(padrão): Open existing database for reading only.'w'
: Open existing database for reading and writing.'c'
: Open database for reading and writing, creating it if it doesn’t exist.'n'
: Always create a new, empty database, open for reading and writing.
mode (int) – The Unix file access mode of the file (default: octal
0o666
), used only when the database has to be created.
Alterado na versão 3.11: file aceita um objeto caminho ou similar.
O objeto retornado por open()
oferece suporte à mesma funcionalidade básica que um dict
; chaves e seus valores correspondentes podem ser armazenados, obtidos e excluídos, e o operador in
e o método keys()
estão disponíveis, bem como métodos get()
e setdefault()
.
Chaves e valores são sempre armazenados como bytes
. Isso significa que quando strings são usadas, elas são implicitamente convertidas para a codificação padrão antes de serem armazenadas.
Estes objetos também oferecem suporte a serem usados em uma instrução with
, que vai fechá-los automaticamente quando estiver concluída.
Alterado na versão 3.2: O métodos get()
e setdefault()
estão agora disponíveis para todos os backends do dbm
.
Alterado na versão 3.4: Adicionado suporte nativo para o protocolo de gerenciamento de contexto para os objetos retornados por open()
.
Alterado na versão 3.8: Excluir uma chave de um banco de dados somente leitura levanta uma exceção de banco de dados específica do módulo em vez de KeyError
.
Os seguintes exemplos registram alguns hostnames e um título correspondente, e então exibe o conteúdo do banco de dados:
import dbm
# Abre o banco de dados, criando-o se necessário.
with dbm.open('cache', 'c') as db:
# Registra alguns valores
db[b'hello'] = b'there'
db['www.python.org'] = 'Python Website'
db['www.cnn.com'] = 'Cable News Network'
# Note que as chaves são consideradas bytes agora.
assert db[b'www.python.org'] == b'Python Website'
# Observe como o valor é agora em bytes.
assert db['www.cnn.com'] == b'Cable News Network'
# Métodos geralmente usados da interface dict funcionam também.
print(db.get('python.org', b'not present'))
# Armazenar uma chave não-string ou valor vai levantar uma exceção
# (provavelmente uma TypeError).
db['www.yahoo.com'] = 4
# db é automaticamente fechado a sair da instrução with.
Ver também
- Módulo
shelve
Módulo persistente que armazena dados não-string.
Os submódulos individuais são descritos nas seções a seguir.
dbm.sqlite3
— Backend de SQLite para dbm¶
Adicionado na versão 3.13.
Código-fonte: Lib/dbm/sqlite3.py
Este módulo usa o módulo da biblioteca padrão sqlite3
para fornecer um backend de SQLite para o módulo dbm
. Os arquivos criados por dbm.sqlite3
podem então ser abertos por sqlite3
ou quaisquer outros navegadores de SQLite, incluindo CLI do SQLite.
Disponibilidade: not WASI.
Este módulo não funciona ou não está disponível em WebAssembly. Veja Plataformas WebAssembly para mais informações.
- dbm.sqlite3.open(filename, /, flag='r', mode=0o666)¶
Abre um banco de dados de SQLite. O objeto retornado se comporta como um mapeamento, implementa um método
close()
e oferece suporte um gerenciador de contexto de “fechamento” via a palavra reservadawith
.- Parâmetros:
filename (path-like object) – O caminho para o banco de dados a ser aberta.
flag (str) –
'r'
(padrão): Open existing database for reading only.'w'
: Open existing database for reading and writing.'c'
: Open database for reading and writing, creating it if it doesn’t exist.'n'
: Always create a new, empty database, open for reading and writing.
mode – O modo de acesso a arquivos do Unix do arquivo (padrão: octal
0o666
), usado apenas quando o banco de dados tem que ser criado.
dbm.gnu
— Gerenciador de banco de dados do GNU¶
Código-fonte: Lib/dbm/gnu.py
O módulo dbm.gnu
fornece uma interface para a biblioteca GDBM, semelhante ao módulo dbm.ndbm
, mas com funcionalidades adicionais, como tolerância a falhas.
Nota
Os formatos de arquivo criados por dbm.gnu
e dbm.ndbm
são incompatíveis e não podem ser usados de forma intercambiável.
Disponibilidade: not Android, not iOS, not WASI.
Este módulo não tem suporte em plataformas móveis ou plataformas WebAssembly.
- exception dbm.gnu.error¶
Levantada em erros específicos do
dbm.gnu
, como erros de E/S.KeyError
é levantada para erros gerais de mapeamento, como especificar uma chave incorreta.
- dbm.gnu.open(filename, flag='r', mode=0o666, /)¶
Abre um banco de dados GDBM e retorna um objeto
gdbm
.- Parâmetros:
filename (path-like object) – O arquivo de banco de dados para abrir.
flag (str) –
'r'
(padrão): Open existing database for reading only.'w'
: Open existing database for reading and writing.'c'
: Open database for reading and writing, creating it if it doesn’t exist.'n'
: Always create a new, empty database, open for reading and writing.
Os seguintes caracteres adicionais podem ser acrescentados para controlar como o banco de dados é aberto:
'f'
: Abre o banco de dados em modo rápido. As gravações no banco de dados não serão sincronizadas.'s'
: Modo sincronizado. Alterações no banco de dados serão gravadas imediatamente no arquivo.'u'
: Não trava o banco de dados.
Nem todos os sinalizadores são válidos para todas as versões do GDBM. Veja o membro
open_flags
para uma lista de caracteres de sinalizadores suportados.mode (int) – The Unix file access mode of the file (default: octal
0o666
), used only when the database has to be created.
- Levanta:
error – Se um argumento flag inválido for passado.
Alterado na versão 3.11: filename aceita um objeto caminho ou similar.
Os objetos
gdbm
se comportam de forma semelhante a mapeamentos, mas os métodositems()
evalues()
não são suportados. Os seguintes métodos também são fornecidos:- gdbm.firstkey()¶
É possível fazer um laço em cada chave no banco de dados usando este método e o método
nextkey()
. A travessia é ordenada pelos valores de hash internos do GDBM e não será classificada pelos valores de chave. Este método retorna a chave inicial.
- gdbm.nextkey(key)¶
Retorna a chave que segue key na travessia. O código a seguir imprime cada chave no banco de dados
db
, sem precisar criar uma lista na memória que contenha todas elas:k = db.firstkey() while k is not None: print(k) k = db.nextkey(k)
- gdbm.reorganize()¶
Se você realizou muitas exclusões e gostaria de reduzir o espaço usado pelo arquivo GDBM, esta rotina reorganizará o banco de dados. Objetos
gdbm
não reduzirão o tamanho de um arquivo de banco de dados, exceto usando esta reorganização; caso contrário, o espaço de arquivo excluído será mantido e reutilizado à medida que novos pares (chave, valor) forem adicionados.
- gdbm.sync()¶
Quando o banco de dados é aberto no modo rápido, esse método força a gravação de todos os dados não gravados no disco.
- gdbm.close()¶
Fecha o banco de dados GDBM.
- gdbm.clear()¶
Remove todos os itens do banco de dados GDBM.
Adicionado na versão 3.13.
dbm.ndbm
— New Database Manager¶
Código-fonte: Lib/dbm/ndbm.py
O módulo dbm.ndbm
fornece uma interface para a biblioteca NDBM. Este módulo pode ser usado com a interface NDBM “clássica” ou a interface de compatibilidade GDBM.
Nota
Os formatos de arquivo criados por dbm.gnu
e dbm.ndbm
são incompatíveis e não podem ser usados de forma intercambiável.
Aviso
A biblioteca NDBM enviada como parte do macOS tem uma limitação não documentada no tamanho dos valores, o que pode resultar em arquivos de banco de dados corrompidos ao armazenar valores maiores que esse limite. Ler esses arquivos corrompidos pode resultar em uma falha grave (falha de segmentação).
Disponibilidade: not Android, not iOS, not WASI.
Este módulo não tem suporte em plataformas móveis ou plataformas WebAssembly.
- exception dbm.ndbm.error¶
Levantada em erros específicos de
dbm.ndbm
, como erros de E/S.KeyError
é levantada para erros gerais de mapeamento, como especificar uma chave incorreta.
- dbm.ndbm.library¶
Nome da biblioteca de implementação NDBM usada.
- dbm.ndbm.open(filename, flag='r', mode=0o666, /)¶
Abre um banco de dados NDBM e retorna um objeto
ndbm
.- Parâmetros:
filename (path-like object) – O nome base do arquivo de banco de dados (sem as extensões
.dir
ou.pag
).flag (str) –
'r'
(padrão): Open existing database for reading only.'w'
: Open existing database for reading and writing.'c'
: Open database for reading and writing, creating it if it doesn’t exist.'n'
: Always create a new, empty database, open for reading and writing.
mode (int) – The Unix file access mode of the file (default: octal
0o666
), used only when the database has to be created.
Os objetos
ndbm
se comportam de forma semelhante a mapeamentos, mas os métodositems()
evalues()
não são suportados. Os seguintes métodos também são fornecidos:Alterado na versão 3.11: Aceita um objeto caminho ou similar como nome de arquivo.
- ndbm.close()¶
Fecha o banco de dados NDBM.
- ndbm.clear()¶
Remove todos os itens do banco de dados NDBM.
Adicionado na versão 3.13.
dbm.dumb
— Implementação portátil do DBM¶
Código-fonte: Lib/dbm/dumb.py
Nota
O módulo dbm.dumb
é pensado como um último recurso alternativo para o módulo dbm
quando um módulo mais robusto não está disponível. O módulo dbm.dumb
não é escrito para velocidade e não é tão usado quanto os outros módulos de banco de dados.
O módulo dbm.dumb
fornece uma interface persistente do tipo dict
que é escrita inteiramente em Python. Ao contrário de outros backends dbm
, como dbm.gnu
, nenhuma biblioteca externa é necessária.
O módulo dbm.dumb
define o seguinte:
- exception dbm.dumb.error¶
Levantada em erros específicos de
dbm.dumb
, como erros de E/S.KeyError
é levantada para erros gerais de mapeamento, como especificar uma chave incorreta.
- dbm.dumb.open(filename, flag='c', mode=0o666)¶
Abre um banco de dados
dbm.dumb
. O objeto banco de dados retornado se comporta de forma semelhante a um mapeamento, além de fornecer os métodossync()
eclose()
.- Parâmetros:
filename – O nome base do arquivo do banco de dados (sem extensões). Um novo banco de dados cria os seguintes arquivos: -
filename.dat
-filename.dir
flag (str) –
'r'
: Open existing database for reading only.'w'
: Open existing database for reading and writing.'c'
(padrão): Open database for reading and writing, creating it if it doesn’t exist.'n'
: Always create a new, empty database, open for reading and writing.
mode (int) – The Unix file access mode of the file (default: octal
0o666
), used only when the database has to be created.
Aviso
É possível travar o interpretador Python ao carregar um banco de dados com uma entrada suficientemente grande/complexa devido a limitações de profundidade de pilha no compilador AST do Python.
Alterado na versão 3.5:
open()
sempre cria um novo banco de dados quando flag é'n'
.Alterado na versão 3.8: Um banco de dados aberto somente leitura se flag for
'r'
. Um banco de dados não é criado se não existir se flag for'r'
ou'w'
.Alterado na versão 3.11: filename aceita um objeto caminho ou similar.
Além dos métodos fornecidos pela classe
collections.abc.MutableMapping
, os seguintes métodos são fornecidos:- dumbdbm.sync()¶
Sincroniza o diretório no disco e os arquivos de dados. Este método é chamado pelo método
shelve.Shelf.sync()
.
- dumbdbm.close()¶
Fecha o banco de dados.