Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/TadaSoftware/PyNFe

Projeto de biblioteca para fazer interface com o webservice de Nota Fiscal eletrônica para Python, disponível sob LGPL.
https://github.com/TadaSoftware/PyNFe

fazenda nf-e nfe python receita sefaz tadasoftware webservice

Last synced: about 1 month ago
JSON representation

Projeto de biblioteca para fazer interface com o webservice de Nota Fiscal eletrônica para Python, disponível sob LGPL.

Awesome Lists containing this project

README

        

## PyNFe

[![Active Development](https://img.shields.io/badge/Maintenance%20Level-Actively%20Developed-brightgreen.svg)](https://gist.github.com/cheerfulstoic/d107229326a01ff0f333a1d3476e068d)
![status](https://img.shields.io/badge/status-stable-green.svg) ![https://github.com/TadaSoftware/PyNFe/actions](https://github.com/TadaSoftware/PyNFe/workflows/PyNFe%20CI/badge.svg?branch=main) ![pyversions](https://img.shields.io/badge/python-3.8%20%7C%203.9%20%7C%203.10%20%7C%203.11%20%7C%203.12-blue)
[![PyPI version](https://badge.fury.io/py/pynfe.svg)](https://badge.fury.io/py/pynfe)

Biblioteca de interface com os webservices de Nota Fiscal Eletrônica (NF-e) e Nota Fiscal de Consumidor Eletrônica (NFC-e) da SEFAZ e Receita Federal do Brasil, Nota Fiscal de Serviço Eletrônica (NFS-e) para Prefeituras e Manifesto de Documentos Fiscais Eletrônicos (MDF-e).

- **NF-e** visa substituir as notas fiscais séries 1 e 1A.
- **NFC-e** visa substituir as notas fiscais modelo 2 e cupom fiscal emitido por ECF.
- **NFS-e** padrão Abrasf para autorizadores Ginfes e Betha.
- **MDF-e** no padrão nacional deverá ser emitido obrigatoriamente no transporte de mercadoria intermunicipais por empresas prestadoras de serviço de transporte ou pelas demais empresas cujo transporte seja realizado em veículos próprios, arrendados ou transportador autônomo.

Características
------------

* NF-e e NFCe:
* Atualizado para a versão 4.00
* Modelo de Documento fiscal 55 e 65
* Configuração para utilização em ambiente de produção e homologação (testes)
* Emissão de notas fiscais normal e em contingência
* Consulta Status do Serviço
* Consultar Cadastro de contribuiente
* Consultar nota fiscal pela chave de acesso
* Consultar protocolo
* Evento de cancelamento de notas
* Evento de carta de correção
* Evento de inutilizar de notas
* Evento de manifestação do destinatário
* Consultar Distribuição DF-e

* NFS-e:
* Emissão de nota fiscal de serviço eletrônico
* Consultar pelo número da NFS-e
* Consultar por RPS (recibo provisório de serviço)
* Consultar Lote
* Cancelar NFS-e

* MDF-e:
* Atualizado para a versão 3.00
* Modelo de Documento 58
* Emissão de Manifesto
* Consultar Status do Serviço
* Consultar MDF-e pela chave de acesso
* Consultar MDF-es não encerrados
* Consultar Recibo
* Evento de Cancelamento
* Evento de Encerramento de viagem
* Evento de Inclusão de Condutor
* Evento de Inclusão de DF-e
* Evento de Pagamento DF-e

* CT-e:
* Atualizado para a versão 3.00
* Consultar Distribuição DF-e para CT-e
* Emissão (A fazer)
* Inutilização (A fazer)
* Consultar CT-e pela chave de acesso (A fazer)
* Consultar Status do Serviço (A fazer)
* Eventos relacionados a CT-e (A fazer)

Dependências
------------

- lxml
- Biblioteca de leitura e gravação de arquivos XML, de alta performance e fácil de implementar.
- signxml
- Assinatura e validação do XML
- pyopenssl
- Biblioteca para manuseio do certificado digital
- requests
- Biblioteca para a comunicação com os webservices da SEFAZ
- suds-jurko (*apenas para NFS-e)
- Biblioteca para a comunicação com os webservices via wsdl
- pyxb (*apenas para NFS-e)
- Biblioteca para geração de bindings a partir de XML Schema(xsd)

Referências
-----------

- Sites oficiais:
- NFe: http://www.nfe.fazenda.gov.br/
- MDF-e: https://dfe-portal.svrs.rs.gov.br/mdfe

- lxml
- http://lxml.de/

- requests
- http://docs.python-requests.org/en/latest/
- https://github.com/psf/requests
- https://pypi.python.org/pypi/requests

- Schemas para validação dos arquivos
- NFe: http://www.nfe.fazenda.gov.br/portal/listaConteudo.aspx?tipoConteudo=BMPFMBoln3w=
- MDFe: https://dfe-portal.svrs.rs.gov.br/Mdfe/Documentos

- Validador de XML
- NFe: https://www.sefaz.rs.gov.br/NFE/NFE-VAL.aspx
- MDFe: https://dfe-portal.svrs.rs.gov.br/MDFE/ValidadorXML

- Validador de assinaturas
- https://servicos.receita.fazenda.gov.br/servicos/assinadoc/ValidadorAssinaturas.app/valida.aspx

Instalação
-----------

```sh
pip install pynfe
```

Instalar versão de desenvolvimento:

```sh
pip install https://github.com/TadaSoftware/PyNFe/archive/refs/heads/main.zip
```

Opcional para NFS-e:

```sh
pip install --user -r https://github.com/TadaSoftware/PyNFe/blob/main/requirements-nfse.txt
```

Exemplos de uso
-----------
- Consulta Status

```python
from pynfe.processamento.comunicacao import ComunicacaoSefaz

certificado = "/home/user/certificado.pfx"
senha = 'senha'
uf = 'pr'
homologacao = True

con = ComunicacaoSefaz(uf, certificado, senha, homologacao)
xml = con.status_servico('nfe')
print(xml.text)
```

Mais exemplos no [Wiki](https://github.com/TadaSoftware/PyNFe/wiki)

Testes
-----------

```sh
python -m unittest
```

Lint
-----------

Instalação: `pip install ruff`
Checar lint: `ruff check .`
Formatar: `ruff format .`

Documentação
-----------
- https://github.com/TadaSoftware/PyNFe/wiki
- http://pynfe.readthedocs.org/pt/latest/

Suporte
-----------
Se tiver qualquer problema or sugestão abra uma issue [aqui](https://github.com/TadaSoftware/PyNFe/issues) ou inicie uma discussão sobre um assunto [aqui](https://github.com/TadaSoftware/PyNFe/discussions).

Quem utiliza PyNFe
-----------
Lista de empresas/projetos que utilizam a lib PyNFe
- Link da lista [aqui](https://github.com/TadaSoftware/PyNFe/wiki/Quem-utiliza-PyNFe).
- Sinta-se livre para incluir o nome da empresa/projeto na lista.

Licença
-----------
PyNFe é licenciada sob a [LGPL-3.0](LICENSE).