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.2.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.2-py3-none-any.whl (12.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: climasus_readdbc_py-0.1.2.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.2.tar.gz
Algorithm Hash digest
SHA256 d731cda528ef35e867a341c43e257742db4b703c39a79cd7e64870c9895489e8
MD5 2449badc656caf15b21458cc7463cbb1
BLAKE2b-256 b3a71c1ae865671ad55f893bec1ff1a6f053008c01de84e1accc830c2acecee5

See more details on using hashes here.

Provenance

The following attestation bundles were made for climasus_readdbc_py-0.1.2.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.2-py3-none-any.whl.

File metadata

File hashes

Hashes for climasus_readdbc_py-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cb07e90663bf0d0510fdec03417949995f91e1e19de2aad1aba34a0a93963fc4
MD5 e296f8567a3fc8caa7a8a4b63490b3af
BLAKE2b-256 069be2438b9e7d5d69b76448db3242931c0b01d67d0646090b4dbbf84871e0ff

See more details on using hashes here.

Provenance

The following attestation bundles were made for climasus_readdbc_py-0.1.2-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