autodevx

cnj-parser

0
0
# Install this skill:
npx skills add autodevx/legal-skills-portal --skill "cnj-parser"

Install specific skill from multi-skill repository

# Description

>

# SKILL.md


name: cnj-parser
description: >
Valida, normaliza e extrai componentes de números de processos judiciais
brasileiros no formato CNJ (NNNNNNN-DD.AAAA.J.TT.OOOO). Use quando
receber números de processo em formatos variados (com ou sem máscara,
colados de sistemas diferentes), precisar validar dígitos verificadores,
identificar tribunal, instância e órgão julgador, ou preparar dados para
consulta em APIs judiciais (DataJud, e-SAJ, PJe, Escavador).
license: MIT
metadata:
author: autodev-tecnologia
version: "1.0.0"
domain: legal-data
personas: [analista, desenvolvedor, legal-ops]
tags: [cnj, processo, tribunal, parser, validação]


Parser de Número CNJ

Formato oficial

O número unificado de processos judiciais segue a Resolução CNJ nº 65/2008:

NNNNNNN-DD.AAAA.J.TT.OOOO
│         │     │ │  └── Órgão julgador (4 dígitos)
│         │     │ └───── Tribunal (2 dígitos)
│         │     └─────── Justiça (1 dígito)
│         └───────────── Ano de distribuição (4 dígitos)
│         └───────────── Dígitos verificadores (2 dígitos)
└─────────────────────── Número sequencial (7 dígitos)

Comportamento esperado

Input aceito

  • Número com máscara: 0002150-34.2023.8.13.0024
  • Número sem máscara: 00021503420238130024
  • Número com espaços ou caracteres extras: 0002150-34.2023.8.13.0024 (TJMG)
  • Lote de números (lista, planilha, texto livre com múltiplos processos)

Passos de processamento

  1. Normalizar: remover tudo que não é dígito
  2. Validar tamanho: deve resultar em exatamente 20 dígitos
  3. Segmentar: separar nos campos NNNNNNN, DD, AAAA, J, TT, OOOO
  4. Validar dígito verificador: algoritmo módulo 97 (Resolução CNJ 65/2008)
  5. Enriquecer: identificar segmento de justiça, tribunal e formatar

Algoritmo de validação (módulo 97)

# Dois passos conforme Resolução CNJ 65/2008
r1 = int(nnnnnnn) % 97
r2 = int(f"{r1:02d}{aaaa}{j}{tt}") % 97
dv_calculado = 98 - (int(f"{r2:02d}{oooo}") % 97)
valido = (dv_calculado == int(dd))

Mapa de segmentos de justiça (campo J)

J Segmento
1 Supremo Tribunal Federal
2 Conselho Nacional de Justiça
3 Superior Tribunal de Justiça
4 Justiça Federal (TRFs 1-6)
5 Justiça do Trabalho (TRTs 1-24)
6 Justiça Eleitoral (TREs)
7 Justiça Militar da União
8 Justiça dos Estados e DF (TJs)
9 Justiça Militar Estadual

Mapa de tribunais (campo TT para J=8 — Justiça Estadual)

TT Tribunal
01 TJAC
05 TJBA
09 TJGO
13 TJMG
17 TJPE
21 TJRS
25 TJSE

Output padrão (processo único)

{
  "input_original": "0002150-34.2023.8.13.0024",
  "valido": true,
  "numero_formatado": "0002150-34.2023.8.13.0024",
  "componentes": {
    "sequencial": "0002150",
    "digito_verificador": "34",
    "ano": "2023",
    "justica_codigo": "8",
    "justica_nome": "Justiça dos Estados e DF",
    "tribunal_codigo": "13",
    "tribunal_sigla": "TJMG",
    "orgao_julgador": "0024"
  },
  "erro": null
}

Output para lote

Ao receber múltiplos números:
1. Extrair todos os padrões de 20 dígitos do texto (com ou sem máscara)
2. Validar cada um individualmente
3. Retornar tabela consolidada com status de cada número
4. Destacar inválidos com causa específica do erro

Formato tabela:

| # | Número CNJ | Válido | Tribunal | Ano | Erro |

Limites

  • Não consulta APIs externas (DataJud, PJe, eSAJ) — apenas parse local
  • Não infere dados além do que o número contém
  • Mapa de tribunais pode não cobrir novos TRFs (ex: TRF-6 criado em 2022)

Script auxiliar

Ver scripts/cnj_validator.py para implementação Python completa com
suporte a batch processing e output JSON/CSV.

# Supported AI Coding Agents

This skill is compatible with the SKILL.md standard and works with all major AI coding agents:

Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.