PyTrustNFe é uma biblioteca para envio de NF-e
Project description
Biblioteca Python que tem por objetivo enviar NFe, NFCe e NFSe no Brasil
Dependências: * PyXmlSec * lxml * signxml * suds * suds_requests * reportlab * Jinja2
Exemplos de uso da NFe
Consulta Cadastro por CNPJ:
from pytrustnfe.nfe import consulta_cadastro from pytrustnfe.certificado import Certificado certificado = open("/path/certificado.pfx", "r").read() certificado = Certificado(certificado, 'senha_pfx') obj = {'cnpj': '12345678901234', 'estado': '42'} resposta = consulta_cadastro(certificado, obj=obj, ambiente=1, estado='42')
Exemplo de uso da NFSe Paulistana
Envio de RPS por lote
certificado = open('/path/certificado.pfx', 'r').read() certificado = Certificado(certificado, '123456') # Necessário criar um dicionário com os dados, validação dos dados deve # ser feita pela aplicação que está utilizando a lib rps = [ { 'assinatura': '123', 'serie': '1', 'numero': '1', 'data_emissao': '2016-08-29', 'codigo_atividade': '07498', 'total_servicos': '2.00', 'total_deducoes': '3.00', 'prestador': { 'inscricao_municipal': '123456' }, 'tomador': { 'tipo_cpfcnpj': '1', 'cpf_cnpj': '12345678923256', 'inscricao_municipal': '123456', 'razao_social': 'Trustcode', 'tipo_logradouro': '1', 'logradouro': 'Vinicius de Moraes, 42', 'numero': '42', 'bairro': 'Corrego', 'cidade': 'Floripa', 'uf': 'SC', 'cep': '88037240', }, 'codigo_atividade': '07498', 'aliquota_atividade': '5.00', 'descricao': 'Venda de servico' } ] nfse = { 'cpf_cnpj': '12345678901234', 'data_inicio': '2016-08-29', 'data_fim': '2016-08-29', 'lista_rps': rps } retorno = envio_lote_rps(certificado, nfse=nfse) # retorno é um dicionário { 'received_xml':'', 'sent_xml':'', 'object': object() } print retorno['received_xml'] print retorno['sent_xml'] # retorno['object'] é um objeto python criado apartir do xml de resposta print retorno['object'].Cabecalho.Sucesso print retorno['object'].ChaveNFeRPS.ChaveNFe.NumeroNFe print retorno['object'].ChaveNFeRPS.ChaveRPS.NumeroRPS
Cancelamento de NFSe:
from pytrustnfe.certificado import Certificado from pytrustnfe.nfse.paulistana import cancelamento_nfe certificado = open('/path/certificado.pfx', 'r').read() certificado = Certificado(certificado, '123456') cancelamento = { 'cnpj_remetente': '123', 'assinatura': 'assinatura', 'numero_nfse': '456', 'inscricao_municipal': '654', 'codigo_verificacao': '789', } retorno = cancelamento_nfe(certificado, cancelamento=cancelamento) # retorno é um dicionário { 'received_xml':'', 'sent_xml':'', 'object': object() } print retorno['received_xml'] print retorno['sent_xml'] # retorno['object'] é um objeto python criado apartir do xml de resposta print retorno['object'].Cabecalho.Sucesso if not retorno['object'].Cabecalho.Sucesso: # Cancelamento com erro print retorno['object'].Erro.Codigo print retorno['object'].Erro.Descricao
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
No source distribution files available for this release.See tutorial on generating distribution archives.
Built Distribution
File details
Details for the file PyTrustNFe-0.1.4-py2-none-any.whl
.
File metadata
- Download URL: PyTrustNFe-0.1.4-py2-none-any.whl
- Upload date:
- Size: 38.5 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 647caf6ece6ae16b83269cba5bdf9f5330ca07833931342be575cff6558b70f2 |
|
MD5 | 4467f06830762f41203db2ffd0f2fd36 |
|
BLAKE2b-256 | fe392d64fb0d97be8eb0b9c8509a03a800d48c54acc3830f9088a357ae06508b |