Obiettivo
Spesso hai bisogno di convalidare la posizione di un luogo. Esistono diversi servizi in Google Maps Platform che possono aiutarti in questo caso d'uso. Questo documento ti aiuta a scegliere tra i due servizi principali di convalida della posizione: l'API Address Validation e l'API Geocoding.
L'API Address Validation è un'offerta di Google Maps Platform che aiuta i clienti a verificare se un indirizzo è corretto o meno.
La geocodifica con l'API Geocoding è il processo di conversione degli indirizzi in coordinate geografiche, che puoi utilizzare per posizionare indicatori su una mappa o una posizione sulla mappa.
Una panoramica generale delle differenze tra l'API Address Validation e l'API Geocoding è disponibile qui.
Quando scegliere l'API Address Validation anziché l'API Geocoding
Note sul diagramma di flusso riportato sopra:
- Il caso d'uso dell'interazione con l'utente si riferisce a quando un utente è presente per interagire con i risultati.
- Places Autocomplete è un'API JavaScript, quindi adatta all'integrazione con le interfacce utente.
- Potresti essere a conoscenza di problemi relativi alla qualità dei dati nei tuoi indirizzi esistenti. Pertanto, anche se potresti volere solo i geocodici, è consigliabile eseguire queste posizioni tramite l'API Address Validation per correggere i set di dati.
Esistono molte situazioni in cui potresti scegliere, in base alla struttura decisionale riportata sopra, di utilizzare un prodotto anziché un altro. Tuttavia, in altre situazioni potrebbe essere necessario utilizzare entrambi i prodotti per raggiungere i tuoi obiettivi.
Potresti scegliere di utilizzare l'API Address Validation anziché l'API Geocoding quando:
- Esiste un'alta probabilità di dati discutibili o in cui ottenere un indirizzo errato avrà un impatto negativo a valle. Questo perché l'API Address Validation fornisce più feedback sul motivo per cui un input non ha ricevuto un risultato di alta precisione.
- Devi correggere gli input utente (ad es. errori ortografici o campi mancanti), il che aumenta la probabilità di un risultato accurato nell'output.
- La tua regione di destinazione restituisce più metadati dall'API Address Validation rispetto all'API Geocoding, ad esempio la classificazione del tipo di edificio come residenziale o commerciale.
Potresti scegliere di utilizzare l'API Geocoding anziché l'API Address Validation quando:
- Il tuo obiettivo principale è recuperare la posizione di un indirizzo e l'accuratezza dei singoli indirizzi potrebbe non essere fondamentale.
- Ad esempio, per generare una mappa termica da un ampio set di dati.
- Hai bisogno di una soluzione globale e l'API Address Validation non è disponibile in tutte le regioni di destinazione.
Di seguito sono riportati alcuni esempi che mostrano le funzionalità dell'API Address Validation rispetto all'API Geocoding.
Esempio di indirizzo non valido
1 Fake St, Mountain View, CA 94043, USA
L'API Address Validation suddivide questo input nei singoli componenti dell'indirizzo (via, città, stato e così via). Può anche fornire un feedback granulare sul motivo per cui l'indirizzo non è valido fino al livello PREMISE
.
Fake St non esiste a Mountain View, in California, e l'API Address Validation lo riflette nei dettagli a livello di componente restituiti:
{
"componentName": {
"text": "Fake St",
"languageCode": "en"
},
"componentType": "route",
"confirmationLevel":"UNCONFIRMED_BUT_PLAUSIBLE"
}
La proprietà importante da esaminare in questo caso è confirmationLevel
. Restituendo UNCONFIRMED_BUT_PLAUSIBLE
per Fake St, l'API ha stabilito che una strada potrebbe avere questo nome, ma non è possibile associarlo ai dati dell'indirizzo di supporto.
Utilizzando il risultato dell'API come feedback, si può dedurre che il componente della via di questo input (Fake St) è errato.
Utilizzando lo stesso indirizzo con l'API Geocoding, è in grado di trovare una corrispondenza con "California", come puoi vedere nello screenshot dello strumento di geocodifica che puoi provare qui:
Tuttavia, il risultato è un geocodice dell'intero stato, con un feedback minimo su quali componenti dell'input erano potenzialmente difettosi.
Esempio di errore ortografico
76 Buckingham Palace Road, Londra, SW1W 9TQ, GB
L'indirizzo sopra riportato contiene un paio di errori ortografici, uno nel nome della via e l'altro nella località.
Sia l'API Address Validation sia l'API Geocoding sono in grado di correggere questi errori e ottenere il risultato 76 Buckingham Palace Road, Londra, SW1W 9TQ. Tuttavia, l'API Address Validation può fornire maggiori informazioni sulla procedura.
Dai un'occhiata a uno dei componenti dell'indirizzo con errori ortografici nell'input:
{
"componentName": {
"text": "Buckingham Palace Road",
"languageCode": "en"
},
"componentType": "route",
"confirmationLevel": "CONFIRMED",
"spellCorrected": true
}
}
L'API Address Validation restituisce un flag per indicare che è stata apportata una correzione al campo. La logica aziendale potrebbe essere implementata in base a questo flag per verificare la correzione con il fornitore di dati, ad esempio un cliente in un pagamento e-commerce.
Esempio di dati mancanti ed errore ortografico
Bollschestraße 86, 12587, DE
L'indirizzo riportato sopra presenta un errore ortografico nel nome della via e manca la città (località) di Berlino.
L'API Address Validation è in grado di correggere entrambi questi errori e restituisce un geocodice a livello PREMISE
e un indirizzo verificato a livello PREMISE
:
Bölschestraße 86, 12587 Berlin, DE
L'API Geocoding non è in grado di superare correttamente gli errori di input in questo caso e restituisce un risultato di ZERO_RESULTS
.
Esempio di metadati di indirizzo aggiuntivi
111 8th Avenue Ste 123, New York, NY 10011-5201, Stati Uniti
Questo indirizzo è corretto, ad eccezione del numero di unità (Ste 123), che non esiste all'interno dell'edificio.
L'API Address Validation è in grado di convalidare l'indirizzo PREMISE
(111 8th Ave) e fornire alcuni metadati sulla proprietà, incluso il fatto che si tratta di un'attività commerciale.
premises:
"business": true
Inoltre, il valore dpvConfirmation
restituito come parte di uspsData
nella risposta è S
:
"dpvConfirmation": "S"
Un valore dpvConfirmation
pari a S
indica che l'indirizzo è convalidato a livello PREMISE
, ma il numero dell'unità fornito nell'input non è associato a quell'indirizzo.
L'API Geocoding non è in grado di fornire queste informazioni.
Informazioni sulla risposta dell'API Geocoding
Panoramica
Se utilizzi l'API Geocoding, il risultato della geocodifica contiene vari indizi nella risposta che possono essere utilizzati per comprendere i dettagli dell'indirizzo fornito.
L'API Geocoding funziona risolvendo i componenti dell'indirizzo in una gerarchia.
Ad **esempio, 123 Example Street, Chicago, 60007, USA
viene risolto nel seguente ordine:
/ Example Street/ Chicago/ 60007/ USA
verranno valutati in questo ordine. In questo caso, la prima corrispondenza è Chicago e, più nello specifico, il codice postale 60007
. Pertanto, restituisce il seguente Place_id per quel codice postale:
ChIJwRKzf8ixD4gRHiXqucwr_HQ
L'API Geocoding contiene le seguenti informazioni nella risposta:
"partial_match": true,
"place_id": "ChIJwRKzf8ixD4gRHiXqucwr_HQ",
"types": [
"postal_code"
]
L'API Geocoding può confermare a quale tipo di luogo appartiene questo indirizzo. Un elenco di types
indirizzi restituito dall'API Geocoding è disponibile qui.
Se nessuno dei componenti dell'input viene risolto, l'API restituisce:
{
"results": [],
"status": "ZERO_RESULTS"
}
Se effettui una richiesta solo con l'indirizzo senza numero civico, il risultato viene restituito nel formato:
"types": [
"route"
]
Ciò significa che l'API Geocoding non è riuscita a trovare o abbinare un numero civico.
Nota:per sapere se un indirizzo esiste, controlla se uno dei parametri (ad esempio types
, partial_match, results, status)
) è impostato nella risposta dell'API Geocoding. In questo modo, il livello di confidenza che un indirizzo possa esistere aumenterà gradualmente, ma non sarà preciso al 100%. Ecco perché abbiamo bisogno dell'API Address Validation.
Puoi utilizzare le tecniche descritte sopra per aumentare l'affidabilità dell'accuratezza dell'indirizzo da una sola risposta dell'API Geocoding. Tuttavia, a differenza di un risultato dell'API Address Validation, l'API Geocoding non restituisce un feedback esatto per determinare l'accuratezza del risultato.
Tipo di posizione
Per comprendere correttamente questa sezione, devi conoscere i diversi tipi di località che potrebbero essere restituiti da una risposta dell'API Geocoding:
- TETTO indica che il risultato restituito è un geocodice preciso per il quale disponiamo di informazioni sulla posizione accurate fino alla precisione dell'indirizzo stradale.
- RANGE_INTERPOLATED indica che il risultato restituito riflette un'approssimazione (di solito su una strada) interpolata tra due punti precisi (ad esempio incroci). I risultati interpolati vengono generalmente restituiti quando i geocodici del tetto non sono disponibili per un indirizzo stradale.
- GEOMETRIC_CENTER indica che il risultato restituito è il centro geometrico di un risultato come una polilinea (ad esempio una strada) o un poligono (regione).
- APPROXIMATE indica che il risultato restituito non è nessuno dei precedenti.
Se un'API Geocoding restituisce un location_type
di ROOFTOP
o RANGE_INTERPOLATED
, non significa necessariamente che l'indirizzo esista. Allo stesso modo, se un'API Geocoding restituisce il flag partial_match
impostato su true
, potrebbe comunque essere il risultato giusto per te.
Questo tipo di corrispondenza errata è un problema molto difficile da risolvere con l'API Geocoding. Come minimo, potresti prendere in considerazione l'implementazione di una convalida di post-elaborazione di base sul paese e sulla località della richiesta / risposta. Ancora meglio, confronta gli indirizzi stradali effettivi per verificare la presenza di errori ortografici e/o di un indirizzo incompleto.
Nota: se decidi di utilizzare l'API Geocoding, ti consigliamo di eseguire regolarmente controlli della qualità dei dati tra la richiesta iniziale e la risposta dell'API Geocoding.
Corrispondenza parziale e corrispondenza errata
Se un indirizzo è una corrispondenza parziale, il che significa che l'API Geocoding non è riuscita a identificarlo esattamente, la risposta contiene:
"partial_match": true,
"types": [
"locality",
"political"
]
Ancora più importante dei tipi di località sopra indicati è considerare quando partial_match = true
è nella risposta. partial_match
indica che l'API Geocoding non ha restituito una corrispondenza esatta per la richiesta originale, anche se è riuscita a trovare una corrispondenza per parte dell'indirizzo richiesto.
Ti consigliamo di esaminare la richiesta originale per verificare se l'indirizzo è incompleto. Le corrispondenze parziali si verificano più spesso per gli indirizzi stradali che non esistono nella località specificata nella richiesta. Le corrispondenze parziali possono essere restituite anche quando una richiesta corrisponde a due o più località nella stessa località.
Ad esempio, "21 Henr St, Bristol, UK
" restituisce una corrispondenza parziale sia per Henry Street che per Henrietta Street. Tieni presente che se una richiesta include un componente dell'indirizzo scritto in modo errato, l'API Geocoding potrebbe suggerire un indirizzo alternativo. I suggerimenti attivati in questo modo non verranno contrassegnati come corrispondenza parziale.
Indirizzi sintetici
L'API Geocoding potrebbe restituire posizioni per indirizzi"sintetici" che non esistono come posizioni precise nel database di Google.
In questi scenari, l'oggetto risposta spesso contiene un ID luogo lungo e la seguente proprietà: geometry.location_type=APPROXIMATE
.
Se riscontri questi indicatori nella risposta, valuta la possibilità di contrassegnare l'indirizzo inserito come non valido e prova a convalidarlo nuovamente con un altro mezzo.
Nota: questo è un altro esempio in cui, con l'API Address Validation, ricevi un feedback diretto se un indirizzo non esiste.
Informazioni sulla risposta dell'API Address Validation
Esiste già un'ottima documentazione su come interpretare le risposte dell'API Address Validation, quindi non entreremo ulteriormente nei dettagli.
- Puoi trovare una panoramica dell'oggetto risposta qui.
- La demo che illustra i diversi componenti della risposta è disponibile qui.
- Nel documento Convalida indirizzo per il pagamento è presente una descrizione dettagliata di come distinguere gli indirizzi validi da quelli non validi.
Best practice
Specificare la regione
Quando effettui chiamate alle API Address Validation o Geocoding, è consigliabile limitare l'area geografica in cui cercare l'indirizzo. Le due API implementano questa funzionalità in due modi diversi:
API Geocoding - Region Biasing
Se sai che i geocodici si troveranno all'interno di un determinato paese, otterrai risultati molto migliori utilizzando la distorsione regionale. Ad esempio, se esegui il geocoding in Canada, ti consigliamo di aggiungere
®ion=ca
alle tue richieste per dare la priorità al Canada. Tieni presente che la preferenza per la regione predilige solo i risultati all'interno di quella regione. Puoi comunque ottenere risultati al di fuori della regione.API Address Validation - Codice regione
Allo stesso modo, l'API Address Validation produce risultati più precisi se nella richiesta viene passato un codice ISO2 utilizzando il campo
regionCode
.
Memorizzazione degli ID luogo
Per memorizzare le informazioni sulla posizione di Google Maps Platform per le richieste future, puoi memorizzare l'ID luogo a tempo indeterminato nel tuo database come attributo della posizione. Dovresti dover effettuare una richiesta Find Place una sola volta per ogni placeID. Puoi anche cercare l'ID luogo ogni volta che un utente richiede i dettagli della transazione.
Per assicurarti di avere sempre le informazioni più aggiornate, aggiorna gli ID luogo ogni 12 mesi utilizzando una richiesta Dettagli luogo con il parametro place_id
.
Nota: assicurati di consultare anche la guida alle best practice per il geocoding.
Conclusione
Questo documento descrive le principali differenze tra le API Address Validation e Geocoding. In sintesi, valuta la possibilità di utilizzare l'API Address Validation quando:
- È necessario un indirizzo postale accurato, soprattutto per motivi di recapito.
- È noto che i dati di input sono di scarsa qualità. L'API Address Validation è più tollerante agli errori di input, evidenzia i componenti dell'indirizzo non verificabili e corregge i dati di input.
- Per un indirizzo sono necessarie ulteriori informazioni, ad esempio Residenziale o Commerciale (disponibile in alcune regioni).
Passaggi successivi
Scarica il white paper Migliora pagamento, consegna e operazioni con indirizzi affidabili e guarda il webinar Migliorare pagamento, consegna e operazioni con la convalida degli indirizzi .
Letture consigliate:
- Address Validation per il pagamento e-commerce
- Documentazione di Place Autocomplete
- Documentazione dell'API Address Validation
- Report Google Maps Platform
Collaboratori
Google gestisce questo articolo. I seguenti collaboratori lo hanno scritto originariamente.
Autori principali:
Henrik Valve | Solutions Engineer
Thomas Anglaret | Solutions Engineer
Sarthak Ganguly | Solutions Engineer