A simple address autocomplete example meant to help improve address quality on government web form submissions.
Data on street names and subdivision names is from the NYS GIS Clearinghouse. A different branch of this project uses data from the U.S. Census Bureau. Note - this example uses data for Onondaga County, NY.
Downloaded shapefiles from the NYS GIS Clearinghouse can be loaded into CartoDB. Then CartoDB's SQL API powers the autocomplete in street name and city / town name fields.
- Download the shapefile for the county where your city or town is located.
- Using your CartoDB account credentials, log in to the CartoDB site.
- Navigate to the Datasets view and click on New Dataset.
- Upload your shapefile and click on Select Dataset.
When your new dataset is created you will see a table view of records. For the purposes of address completion, we are interested in three fields - streetname
+ posttype
will give us unique street names to assist in completing the Street Name field, and citytownna
which will give us the unique name of cities and towns for completing the City / Town field.
For example, to look up a list of unqiue street names for streets beginning with 'Green', we would use:
SELECT DISTINCT(streetname || ' ' || posttype) AS street FROM addresspoints_onondaga WHERE streetname LIKE 'Green%'
To look up the unique names for all cities and towns we would use:
SELECT DISTINCT(citytownna) FROM addresspoints_onondaga
Here is an example API call for street names beginning with Green
. We append our SQL query from above to the end of the URL for the CartoDB SQL API (which includes your CartoDB username - see below). Note, the SQL query must be URL encoded in order to work properly. Your browser will typically do this automatically, but other tools and frameworks may not unless you explicitly do this:
https://{username}.cartodb.com/api/v2/sql?q=SELECT%20DISTINCT(streetname%20%7C%7C%20%27%20%27%20%7C%7C%20posttype)%20AS%20street%20FROM%20addresspoints_onondaga%20WHERE%20streetname%20LIKE%20%27Green%20%25%27
The response we get back looks like this:
{
"total_rows": 16,
"fields": {
"fullname": {
"type": "string"
}
},
"time": 0.004,
"rows": [
{
"fullname": "Green Street Pl"
},
{
"fullname": "Green Fir Cir"
},
{
"fullname": "Green Meadow"
},
{
"fullname": "Green River Way"
},
{
"fullname": "Green St"
},
{
"fullname": "Green Lakes Rd"
},
{
"fullname": "Green St Annex"
},
{
"fullname": "Green Lake Rd"
},
{
"fullname": "Green Lakes Park Dr"
},
{
"fullname": "Green St"
},
{
"fullname": "Green Lakes Park Ter"
},
{
"fullname": "Green Meadow"
},
{
"fullname": "Green Acres Dr"
},
{
"fullname": "Green St"
},
{
"fullname": "Green Street Ct"
},
{
"fullname": "Green Street Aly"
}
]
}
- Bootstrap / Bootswatch
- jQuery
- jQuery EasyAutocomplete
- jQuery Validate
- CartoDB