Skip to main content

CLI per il SITUAS (Sistema Informativo Territoriale delle Unità Amministrative e Statistiche, ISTAT), pensata per l'orchestrazione da parte di agenti AI

Project description

PyPI version GitHub Ask DeepWiki License: MIT Newsletter

opensituas

CLI per il SITUAS — Sistema Informativo Territoriale delle Unità Amministrative e Statistiche (ISTAT) — progettata per essere orchestrata da un agente AI: output strutturato (table/json/csv), errori auto-esplicativi, catalogo cachato.

opensituas è un'idea di Alice Corona.

Installazione

uv tool install opensituas        # CLI a livello di sistema
# oppure, in sviluppo:
uv pip install -e .

Cosa espone SITUAS

Due tipi di interrogazione, entrambi coperti:

  1. Catalogo report — 74 "microservizi" (report) su unità amministrative e statistiche (ripartizioni, regioni, province/uts, comuni, sistemi locali del lavoro, ...). Ogni report ha un periodo di validità e restituisce una tabella alla data scelta.
  2. Query territoriali interattive — storia delle variazioni di un'unità nel tempo (storia) e ricerca dei codici/denominazioni Istat con periodi di validità (cerca-codice).

Comandi

# --- catalogo ---
opensituas catalog                          # tutti i report (pfun, titolo, validità, ...)
opensituas catalog "Comuni" --ambito "Unità amministrative"
opensituas --output json catalog "Ripartizioni" | jq '.[].pfun'
opensituas catalog --refresh                # rilegge dal gateway

opensituas info 50                          # descrizione + colonne del report 50
opensituas get 61                           # report DATA: dato più recente (fine validità)
opensituas get 61 --output csv --out comuni.csv
opensituas count 98 --from 17/03/1861 --to 31/05/2026
opensituas get 61 --date 01/01/2020         # snapshot storico; errore chiaro se fuori validità

# --- query territoriali ---
opensituas storia comune Roma               # storia delle variazioni del comune
opensituas storia comune 058091 --dettaglio # + provvedimento e unità coinvolte
opensituas storia regione Lazio
opensituas storia provincia Roma
opensituas cerca-codice comune Roma         # codici/denominazioni + validità

# --- per agenti AI ---
opensituas agent-context                    # JSON versionato: schema CLI (comandi, flag, exit code)
opensituas which "comuni per anno"          # trova report SITUAS da linguaggio naturale
opensituas which --limit 1 province        # max 1 risultato; exit 2 se nessun match
opensituas -o json which "province cessate" | jq '.[].comando_suggerito'

Casi d'uso

Codici ufficiali Istat — la master table per i join

Il punto di partenza di qualsiasi analisi che usa dati pubblici italiani. Il report 61 è una riga per comune con tutti i livelli gerarchici (ripartizione, regione, provincia, comune) e le denominazioni ufficiali. Chiave di join universale: PRO_COM_T (6 caratteri alfanumerici, es. 015146).

opensituas -o csv get 61 --out comuni.csv              # snapshot corrente
opensituas -o csv get 61 --date 01/01/2000 --out comuni_2000.csv

Popolazione, superficie e caratteristiche per comune

Due report complementari per normalizzare qualsiasi dataset comunale.

opensituas -o csv get 74 --out comuni_dim.csv     # POP_LEG, POP_RES, AREA_KMQ, anno riferimento
opensituas -o csv get 73 --out comuni_car.csv     # COM_LIT (litoraneo), COM_ISO (isolano), ZONA_ALT

ZONA_ALT: 1=Montagna interna · 2=Montagna litoranea · 3=Collina interna · 4=Collina litoranea · 5=Pianura. Join via PRO_COM_T.

Aree interne, montagna e zone di svantaggio

Fondamentale per giornalismo sui piccoli comuni, divario territoriale, accesso ai servizi.

opensituas -o csv get 75 --out comuni_policy.csv

Campi chiave: AREE_INT_2020 (Polo → Polo intercomunale → Cintura → Intermedio → Periferico → Ultraperiferico), MACRO_AI_2020 (due classi: interno/non interno), ZONE_MONTANE_2014, ZONE_V_NAT_2020 (vincoli naturali), ZONE_S_SPECIFICI_2014.

La storia di un comune — fusioni, rinominazioni, soppressioni

opensituas storia comune "Ledro" --dettaglio       # nato da fusione: chi, quando, perché
opensituas storia comune "Sesto San Giovanni"
# Tutte le variazioni dal 1991 a oggi con testo del provvedimento:
opensituas -o csv get 129 --out variazioni_1991.csv
# Solo cambi di denominazione, dall'Unità d'Italia:
opensituas -o json get 104 --from 17/03/1861 --to 31/05/2026 | jq '.[].COMUNE'

Il report 129 (Variazioni amministrative e territoriali dal 1991) è il più ricco: DESC_COD_VARIAZIONE descrive il tipo (fusione, scorporo, cambio nome, cambio codice...), TESTO_PROVVEDIMENTO riporta la norma di riferimento.

Confrontare dati storici — traslazione codici tra due date

Indispensabile quando si confrontano dataset di anni diversi: le fusioni cambiano i codici.

# Mapping codici comuni: come erano nel 2001, come sono oggi
opensituas -o csv get 99 --from 21/10/2001 --to 31/12/2024 --out mapping_2001_2024.csv
# Affiancamento completo: chi c'era nel 2011 e nel 2021 (con eventuali blank per nuovi/soppressi)
opensituas -o csv get 298 --from 01/01/2011 --to 01/01/2021 --out confronto_2011_2021.csv

Sistemi Locali del Lavoro e specializzazione produttiva

I SLL raggruppano comuni per bacino di pendolarismo — l'unità di analisi del mercato del lavoro locale. Il report delle tassonomie ha anche la specializzazione produttiva del SLL.

opensituas -o csv get 408 --out sll_composizione.csv   # quali comuni appartengono a ogni SLL
opensituas -o csv get 444 --out sll_tassonomie.csv     # CL_DIM, CLASSE_2021_NAME, GRUPPO_2021_NAME

CLASSE_2021_NAME / GRUPPO_2021_NAME: specializzazione produttiva (es. distretto manifatturiero, turismo, servizi). Utile per confronti tra aree economicamente simili.

Cities, FUA e NUTS — classificazioni geografiche europee

Per analisi comparate con dati EUROSTAT o europei in genere.

opensituas -o csv get 414 --out cities_2021.csv      # comuni nelle "Cities" (definizione EUROSTAT)
opensituas -o csv get 446 --out fua_2021.csv         # comuni nelle Zone Urbane Funzionali 2021
opensituas -o csv get 449 --out nuts3.csv            # POP_RES, AREA_KMQ, urban/rural, costiero, confine

Il report 449 (NUTS 3 - Dimensione e classificazioni) include COD_URBAN_RURAL (tipologia urbano-rurale a livello provinciale), COD_COASTAL e COD_BORDER_REGION — le classificazioni standardizzate EUROSTAT per i confronti tra paesi.


Output per agenti

Il flag globale --output (-o) vale table (default), json o csv. In json/csv l'output su stdout è pulito (i messaggi diagnostici vanno su stderr), pronto per jq:

opensituas -o json storia comune Roma | jq '.storia[] | {data: ."data evento", evento: .variazione}'
opensituas -o csv get 50 > comuni.csv

Come funziona (in breve)

  • Catalogo: ottenuto via gateway POST (get_elenco_microservizi), cachato in ~/.cache/opensituas/catalog.json (TTL 7 giorni), con snapshot incluso come fallback.
  • Dati report: endpoint pubblici situas-servizi.istat.it/publish (reportspooljson, reportspooljsoncount, anagrafica_report_metadato_web). Per i report DATA, senza --date la CLI usa la fine validità (dato più recente); i link del catalogo porterebbero invece la data di inizio (snapshot più vecchio). --date/--from/--to sostituiscono il parametro data.
  • Query territoriali: servizi var_get_ua_* (storia) e ricercacodice_* via gateway.

Dettagli in docs/architecture.md. Per orchestrazione da agente vedi skills/situas-explorer/SKILL.md.

Variabili d'ambiente

Variabile Default Descrizione
OPENSITUAS_TIMEOUT 60 Timeout richieste (secondi)

Licenza

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

opensituas-0.1.2.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

opensituas-0.1.2-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file opensituas-0.1.2.tar.gz.

File metadata

  • Download URL: opensituas-0.1.2.tar.gz
  • Upload date:
  • Size: 19.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for opensituas-0.1.2.tar.gz
Algorithm Hash digest
SHA256 2d9f56bcd6596fc2607e5561af306637844b33b614d912ada9e2a345a0670eaf
MD5 2b328eef21c8ad6226c1f6b6350794e9
BLAKE2b-256 501f60334b417745addde73f8f03ab8ecc5277cfaaec29c6cc668743345b2a55

See more details on using hashes here.

File details

Details for the file opensituas-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: opensituas-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for opensituas-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 61cfbd5cfe0d4d3f937824bf2d5da95b5b34ae4339013cc671c59dfd52560118
MD5 707aa181379a245928c7e17847d54f38
BLAKE2b-256 3e2d501a63d54e4902f4ac21ddc65154c8c089b87747f94e3579f0d40519a886

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page