Skip to main content

Pure-Python reader for DATASUS .dbc files (blast-compressed dBASE III)

Project description

readdbc

PyPI version CI Python Versions License: MIT

Leitor puro-Python para arquivos .dbc do DATASUS — formato dBASE III com compressão PKWARE blast. Sem dependências C, sem compilador necessário.


Instalação

pip install climasus_readdbc_py

Requisitos: Python ≥ 3.10, pandas ≥ 2.0


Uso rápido

import readdbc

# Ler arquivo .dbc diretamente como DataFrame pandas
df = readdbc.read_dbc("DOSP2023.dbc")

# Ler arquivo .dbf comum
df = readdbc.read_dbf("dados.dbf")

# Descomprimir bytes brutos de um .dbc para .dbf
with open("DOSP2023.dbc", "rb") as f:
    compressed = f.read()

raw_dbf_bytes = readdbc.blast_decompress(compressed)

O formato DBC

Os arquivos .dbc são distribuídos pelo DATASUS para transferência eficiente dos microdados do SUS (Sistema Único de Saúde). Internamente, são arquivos dBASE III (.dbf) cujo bloco de registros foi comprimido com o algoritmo PKWARE DCL Implode (também chamado de blast).

Layout interno:

[0 .. H)       Cabeçalho DBF não comprimido (H = uint16 LE nos bytes 8-9)
[H .. H+4)     4 bytes de CRC / padding (ignorados)
[H+4 .. EOF)   Dados comprimidos com PKWare blast

A descompressão produz: cabeçalho_dbf + registros_descomprimidos = DBF completo.


API de referência

Função / Classe Descrição
read_dbc(path) Lê um .dbc e retorna pd.DataFrame
read_dbf(path) Lê um .dbf e retorna pd.DataFrame
blast_decompress(b) Descomprime bytes brutos do formato blast
dbc_to_dbf(b) Converte bytes .dbc para bytes .dbf
BlastError Exceção para erros de descompressão
DBFError Exceção para erros de leitura DBF
DBCError Exceção para erros de leitura DBC

Projeto ClimaSUS

Este pacote faz parte do ecossistema ClimaSUS — plataforma de análise de dados climáticos e de saúde pública do SUS.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

climasus_readdbc_py-0.1.1.tar.gz (14.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

climasus_readdbc_py-0.1.1-py3-none-any.whl (12.6 kB view details)

Uploaded Python 3

File details

Details for the file climasus_readdbc_py-0.1.1.tar.gz.

File metadata

  • Download URL: climasus_readdbc_py-0.1.1.tar.gz
  • Upload date:
  • Size: 14.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for climasus_readdbc_py-0.1.1.tar.gz
Algorithm Hash digest
SHA256 9f645f014de32427e9e2e5f1dbaea00e6a2aaec35a59ddc3b8f8ebc989ded457
MD5 67b544d1de7ad5b0c5ea37dfda27c5ec
BLAKE2b-256 52e18668e3bc133ace050a7860730361788733c6e863dba50307b6b0604b3fc1

See more details on using hashes here.

Provenance

The following attestation bundles were made for climasus_readdbc_py-0.1.1.tar.gz:

Publisher: publish.yml on climasus/climasus_readdbc_py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file climasus_readdbc_py-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for climasus_readdbc_py-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 68575b5a65cb3c66e7a5be33b63867eff7f224991ec2f7d374c4bd063aaa21f1
MD5 c6711cac392478f49d23ea9551e29f2c
BLAKE2b-256 b0b4b7f6b686cfb5f835f090e364cff88e10abe99c0bdc923b7390a32a5ea813

See more details on using hashes here.

Provenance

The following attestation bundles were made for climasus_readdbc_py-0.1.1-py3-none-any.whl:

Publisher: publish.yml on climasus/climasus_readdbc_py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page