"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:

* "dbm.sqlite3"

* "dbm.gnu"

* "dbm.ndbm"

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 quando
   "dbm.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"
   ou "dbm.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 existe

   * a string vazia ("''") se o formato do arquivo não puder ser
     adivinhado

   * uma 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*.

The object returned by "open()" supports the basic functionality of
mutable *mappings*; keys and their corresponding values can be stored,
retrieved, and deleted, and iteration, the "in" operator and methods
"keys()", "get()", "setdefault()" and "clear()" are available. The
"keys()" method returns a list instead of a view object. The
"setdefault()" method requires two arguments.

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".

Alterado na versão 3.13: "clear()" methods are now available for all
"dbm" backends.

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)

   Open an SQLite database.

   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.

   The returned database object behaves similar to a mutable
   *mapping*, but the "keys()" method returns a list, and the
   "setdefault()" method requires two arguments. It also supports a
   "closing" context manager via the "with" keyword.

   O seguinte método também é fornecido:

   sqlite3.close()

      Close the SQLite database.


"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 (GNU
dbm), 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_flags

   Uma sequência de caracteres que o parâmetro *flag* de "open()"
   suporta.

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*.

   "gdbm" objects behave similar to mutable *mappings*, but methods
   "items()", "values()", "pop()", "popitem()", and "update()" are not
   supported, the "keys()" method returns a list, and the
   "setdefault()" method requires two arguments. It also supports a
   "closing" context manager via the "with" keyword.

   Alterado na versão 3.2: Added the "get()" and "setdefault()"
   methods.

   Alterado na versão 3.13: Added the "clear()" method.

   The following methods are also provided:

   gdbm.close()

      Fecha o banco de dados GDBM.

   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.


"dbm.ndbm" --- New Database Manager
===================================

**Código-fonte:** Lib/dbm/ndbm.py

======================================================================

O módulo "dbm.ndbm" fornece uma interface para a biblioteca NDBM (New
Database Manager). Este módulo pode ser usado com a interface NDBM
"clássica" ou a interface de compatibilidade GDBM (GNU dbm).

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.

   Alterado na versão 3.11: Aceita um *objeto caminho ou similar* como
   nome de arquivo.

   "ndbm" objects behave similar to mutable *mappings*, but methods
   "items()", "values()", "pop()", "popitem()", and "update()" are not
   supported, the "keys()" method returns a list, and the
   "setdefault()" method requires two arguments. It also supports a
   "closing" context manager via the "with" keyword.

   Alterado na versão 3.2: Added the "get()" and "setdefault()"
   methods.

   Alterado na versão 3.13: Added the "clear()" method.

   O seguinte método também é fornecido:

   ndbm.close()

      Fecha o banco de dados NDBM.


"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)

   Open a "dbm.dumb" database.

   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*.

   The returned database object behaves similar to a mutable
   *mapping*, but the "keys()" and "items()" methods return lists, and
   the "setdefault()" method requires two arguments. It also supports
   a "closing" context manager via the "with" keyword.

   The following methods are also provided:

   dumbdbm.close()

      Fecha o banco de dados.

   dumbdbm.sync()

      Sincroniza o diretório no disco e os arquivos de dados. Este
      método é chamado pelo método "shelve.Shelf.sync()".
