CLI per il SITUAS (Sistema Informativo Territoriale delle Unità Amministrative e Statistiche, ISTAT), pensata per l'orchestrazione da parte di agenti AI
Project description
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:
- 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.
- 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 reportDATA, senza--datela CLI usa la fine validità (dato più recente); i link del catalogo porterebbero invece la data di inizio (snapshot più vecchio).--date/--from/--tosostituiscono il parametro data. - Query territoriali: servizi
var_get_ua_*(storia) ericercacodice_*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
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 Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2d9f56bcd6596fc2607e5561af306637844b33b614d912ada9e2a345a0670eaf
|
|
| MD5 |
2b328eef21c8ad6226c1f6b6350794e9
|
|
| BLAKE2b-256 |
501f60334b417745addde73f8f03ab8ecc5277cfaaec29c6cc668743345b2a55
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
61cfbd5cfe0d4d3f937824bf2d5da95b5b34ae4339013cc671c59dfd52560118
|
|
| MD5 |
707aa181379a245928c7e17847d54f38
|
|
| BLAKE2b-256 |
3e2d501a63d54e4902f4ac21ddc65154c8c089b87747f94e3579f0d40519a886
|