## Contas / CPFL / Download + OCR
Faz download da conta de energia elétrica mais recente na Agência Virtual da CPFL e retorna os dados da conta lidos com OCR.


### Site URL
- https://servicosonline.cpfl.com.br/agencia-webapp/#/home

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/contas/cpfl/download-ocr`



| Parameter   | Description                                                 |
| ----------- | ----------------------------------------------------------- |
| token*      | The token that will authenticate and authorize the request. |
| email*      | Email utilizado para fazer login.                           |
| senha*      | Senha.                                                      |
| instalacao* | Número da instalação.                                       |

> * 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": "contas/cpfl/download-ocr",
    "parameters": {
      "email": "empresa@email.com",
      "instalacao": "11111111",
      "senha": ""
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.28",
    "requested_at": "2020-08-17T14:57:09.000-03:00",
    "elapsed_time_in_milliseconds": 14531,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX18300lyE10sa1AczF/U4pGLB/QHh4efsKYTleBl5V82t7UlA7ic7B4A6qUG3+kItCiZu4jaXs2wbg=="
  },
  "data_count": 1,
  "data": [
    {
      "conta_paga": false,
      "instalacao": "11111111",
      "mes": "2020/07",
      "nome": "Nome de Exemplo",
      "normalizado_valor": 77.2,
      "normalizado_vencimento": "25/08/2025",
      "ocr": [
        {
          "ano": 2020,
          "cliente": {
            "cpf": "",
            "cnpj": "11.111.111/1111-11",
            "nome": "Nome de Exemplo",
            "instalacao": "11111111",
            "classificao": "",
            "pn": "701928772",
            "normalizado_cpf": "",
            "normalizado_cnpj": "11111111111111",
            "classificacao": "Convencional B2 Rural Agropecuária Rural - Trifásico 220 / 127 V"
          },
          "codigo_barras": "111111111111111111111111111111111111111111111111",
          "endereco": "Avenida Paulista",
          "energia": {
            "energia_ativa_injetada_te": "",
            "normalizado_energia_ativa_injetada_te": 0,
            "saldo_energia_instalacao": "",
            "normalizado_saldo_energia_instalacao": "1",
            "tarifa_aneel_tusd": "",
            "normalizado_tarifa_aneel_tusd": 0,
            "tarifa_aneel_te": "",
            "normalizado_tarifa_aneel_te": 0,
            "bandeiras_tarifarias": "Verde 12 Dias Vermelha P2 19 Dias",
            "historico_consumo": [
              {
                "periodo": "2020 DEZ",
                "kwh": "790",
                "dias": "31"
              },
              {
                "periodo": "NOV",
                "kwh": "1030",
                "dias": "29"
              },
              {
                "periodo": "OUT",
                "kwh": "760",
                "dias": "32"
              },
              {
                "periodo": "SET",
                "kwh": "1070",
                "dias": "31"
              },
              {
                "periodo": "AGO",
                "kwh": "510",
                "dias": "32"
              },
              {
                "periodo": "JUL",
                "kwh": "1080",
                "dias": "29"
              },
              {
                "periodo": "JUN",
                "kwh": "720",
                "dias": "29"
              },
              {
                "periodo": "MAI",
                "kwh": "1090",
                "dias": "32"
              },
              {
                "periodo": "ABR",
                "kwh": "1390",
                "dias": "30"
              },
              {
                "periodo": "MAR",
                "kwh": "1060",
                "dias": "31"
              },
              {
                "periodo": "FEV",
                "kwh": "1190",
                "dias": "28"
              },
              {
                "periodo": "JAN",
                "kwh": "1070",
                "dias": "32"
              },
              {
                "periodo": "2019 DEZ",
                "kwh": "1370",
                "dias": "29"
              }
            ]
          },
          "leitura_data": "11/11/1111",
          "mes": 12,
          "normalizado_valor": 553.34,
          "nota_fiscal": {
            "numero_serie": "Nº 111111111 Série C",
            "apresentacao_data": "11/11/1111",
            "pis": "1,11%",
            "cofins": "3,84%",
            "icms": "18,00"
          },
          "proxima_leitura_data": "11/11/1111",
          "valor": "553,34",
          "vencimento": "13/01/2021"
        }
      ],
      "valor": "1147,97",
      "vencimento": "2020-08-13T00:00:00",
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://www.exemplo.com/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/contas/cpfl/download-ocr'
args = {
  "email":      "VALUE_OF_PARAMETER_EMAIL",
  "senha":      "VALUE_OF_PARAMETER_SENHA",
  "instalacao": "VALUE_OF_PARAMETER_INSTALACAO",
  "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.
