## SEFAZ / SP / NFE
Consulta resumida de Nota Fiscal eletrônica (modelo 55) no estado de São Paulo.


### Site URL
- https://nfe.fazenda.sp.gov.br/ConsultaNFe/consulta/publica/ConsultarNFe.aspx

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/sefaz/sp/nfe`



| Parameter | Description                                                 |
| --------- | ----------------------------------------------------------- |
| token*    | The token that will authenticate and authorize the request. |
| nfe*      | Access key of the NF-e.                                     |

> * Required parameter.

> ** Optional parameter. Sometimes it is necessary to set at least one of the optional parameters for the service to work properly.


### Response examples (OK)
```json
{
  "code": 200,
  "code_message": "A requisição foi processada com sucesso.",
  "errors": [],
  "header": {
    "api_version": "v2",
    "service": "sefaz/sp/nfe",
    "parameters": {
      "nfe": "11111111111111111111111111111111111111111111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.2",
    "requested_at": "2019-08-08T16:30:55.000-03:00",
    "elapsed_time_in_milliseconds": 13936,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX19lRw5yyjTz02daOrrhARdIhTywYnAOhy/XaCUAdKxjAFSJlkrDpb2K8Sv47PXJS6/dUb+cDm1hiQ=="
  },
  "data_count": 1,
  "data": [
    {
      "dados_da_nfe": {
        "natureza_da_operacao": "V E N D A",
        "tipo_da_operacao": "1 - Saída",
        "chave_de_acesso": "11-1111-11111111111111-11-111-111111111-111111111-1",
        "modelo": "55",
        "serie": "0",
        "numero": "11111",
        "data_hora_da_emissao": "17/11/2016 12:15:30-02:00"
      },
      "destinatario": {
        "cnpj": "**.***.111/1111-11",
        "ie": "111111111",
        "nome_razao_social": "Nome de Exemplo",
        "municipio": "São Paulo",
        "uf": "SP",
        "pais": "Nome de Exemplo"
      },
      "digest_value": "AAAA11AAAAAAAA1AAAAAAAAAA1A=",
      "emitente": {
        "cnpj": "11.111.111/1111-11",
        "ie": "111111111111",
        "nome_razao_social": "Nome de Exemplo",
        "municipio": "São Paulo",
        "uf": "SP"
      },
      "eventos_e_servicos": [
        {
          "evento": "Autorização de Uso",
          "protocolo": "111111111111111",
          "data_autorizacao": "11/11/1111 às 11:11:11"
        },
        {
          "evento": "Carta de Correção Eletrônica ()",
          "protocolo": "111111111111111",
          "data_autorizacao": "11/11/1111 às 11:11:11-11:11"
        },
        {
          "evento": "Carta de Correção Eletrônica ()",
          "protocolo": "111111111111111",
          "data_autorizacao": "11/11/1111 às 11:11:11-11:11"
        }
      ],
      "produtos": [
        {
          "descricao": "",
          "quantidade": "1,1111",
          "unidade": "PC",
          "valor_unitario": "110,10",
          "valor_produto": "220,20"
        },
        {
          "descricao": "",
          "quantidade": "1,1111",
          "unidade": "PC",
          "valor_unitario": "110,10",
          "valor_produto": "220,20"
        },
        {
          "descricao": "",
          "quantidade": "1,1111",
          "unidade": "PC",
          "valor_unitario": "110,10",
          "valor_produto": "220,20"
        }
      ],
      "site_receipt": "https://api.infosimples.com/receipt/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://api.infosimples.com/receipt/exemplo-de-url"
  ]
}
```


### Preview file

The preview file (`site_receipts`) in the response JSON is **generated by the source (website/app)** that processed the automation.

### Code snippets


#### Python
```python
# Tested with: Python 3.10.19, Python 3.14.0
import requests

url = 'https://api.infosimples.com/api/v2/consultas/sefaz/sp/nfe'
args = {
  "nfe":     "VALUE_OF_PARAMETER_NFE",
  "token":   "WRITE_YOUR_TOKEN_HERE",
  "timeout": "300"
}

response = requests.post(url, args)
response_json = response.json()
response.close()

if response_json['code'] == 200:
  print("Retorno com sucesso: ", response_json['data'])
elif response_json['code'] in range(600, 799):
  mensagem = "Resultado sem sucesso. Leia para saber mais: \n"
  mensagem += "Código: {} ({})\n".format(response_json['code'], response_json['code_message'])
  mensagem += "; ".join(response_json['errors'])
  print(mensagem)

print("Cabeçalho da consulta: ", response_json['header'])
print("URLs com arquivos de visualização (HTML/PDF): ", response_json['site_receipts'])
```


## We are here to help
Do you still need to figure something out? Reach us at [suporte@infosimples.com.br](mailto:suporte@infosimples.com.br) and our highly qualified support team will be happy to help.
