Extended geocoding
Extended geocoding returns address information and coordinates from the queried text (address) string. Unlike the standard geocoding, the API gives greater importance to postal code for ordering of results, returns match score value of the returned and allows the address to be entered as separate elements (however, it's not mandatory). To increase the chance of getting results, a multi-level approach is being used in the backend, if the first step is unsuccesful, the geocoder becomes less strict at the next steps. If it's impossible to get correct address, only the location of the populated place might be returned.
Only Baltics' addresses can be geocoded. The official Latvian, Estonian and Lithuanian address databases are being used as the data source. Navigation coordinates of the closest point of the routable road network for motor vehicles are calculated using the Jāņa sēta road network.
API URL
The request URL should match the following pattern:
https://api.kartes.lv/v3/KVDM_jb1kd/ext-geocoding?
The response is given in XML.
The HTTP GET request method is used.
Query parameters
The request consists of the following GET parameters:
Parameter | Description | Values |
---|---|---|
country | Country code (Alpha-2 code). |
|
city | Populated place (city, town, village), administrative or teritorial unit. | |
street | Street name. If an address isn't split by its elements, you can pass full string here. | |
housenumber | House number or name. | |
postalcode | Postal code. | |
maxresults | Max results. You can get up to 25 results. |
Response parameters
The response consists of an array of objects. See below the description of each object.
MatchScore object
Parameter | Description |
---|---|
Score | Match level score (from 0 to 100). |
MatchLevel | Match level as following categories, "houseNumber", "city", "street", "district" (see Address object). |
Location object
Parameter | Description |
---|---|
MapLocationId | Unique code of the returned location. |
LocationType | Location type. |
DisplayCoordinate object
Returns the WGS coordinates of the address point.
Parameter | Description |
---|---|
Latitude | Latitude coordinate in the WGS-84 projection (EPSG:4326). |
Longitude | Longitude coordinate in the WGS-84 projection (EPSG:4326). |
NavigationCoordinate object
Returns the WGS coordinates of the nearest point on the road network to the returned address point.
Parameter | Description |
---|---|
Latitude | Latitude coordinate in the WGS-84 projection (EPSG:4326) |
Longitude | Longitude coordinate in the WGS-84 projection (EPSG:4326). |
Address object
Parameter | Description |
---|---|
Label | Full address. |
Country | Country code (LV - Latvia, LT - Lithuania, EE - Estonia). |
County | Administrative unit. |
District | Territorial unit. Returns empty if matches city name (like Cēsis and Cēsu pilsēta). |
City | Populated place (city, town, village). |
Street | Street name or house name (if the address lacks the street element) |
HouseNumber | House number or name if the address has a street name. |
PostalCode | Postal code. |
Error codes
Code | Description |
---|---|
200 | Wrong input data. |
404 | No location found. |
5xx | Server error. |
Examples
Input:
https://api.kartes.lv/v3/KVDM_jb1kd/ext-geocoding?city=Rīga&postalcode=1020&street=Krasta%20iela&housenumber=105A&maxresults=1
Output:
<LocationMatch>
<Matching>
<Score>93</Score>
<MatchLevel>houseNumber</MatchLevel>
<MatchingScore>
<City>93</City>
<Street>93</Street>
<HouseNumber>93</HouseNumber>
<Country>100</Country>
</MatchingScore>
<MatchType>pointAddress</MatchType>
</Matching>
<Location>
<MapLocationId>89ada520023eb349957e9e4a93f2270b</MapLocationId>
<LocationType>address</LocationType>
<DisplayCoordinate>
<Latitude>56.921337</Latitude>
<Longitude>24.168581</Longitude>
</DisplayCoordinate>
<NavigationCoordinate>
<Latitude>56.921178</Latitude>
<Longitude>24.168718</Longitude>
</NavigationCoordinate>
<Address>
<Label>Krasta iela 105A, Rīga, Latgales priekšpilsēta, Latvija</Label>
<Country>LV</Country>
<County>Rīga</County>
<City>Rīga</City>
<District>Latgales priekšpilsēta</District>
<Street>Krasta iela</Street>
<HouseNumber>105A</HouseNumber>
<PostalCode>1019</PostalCode>
<AdditionalData key="CountryName">Latvija</AdditionalData>
<AdditionalData key="CountyName">Rīga</AdditionalData>
</Address>
</Location>
</LocationMatch>
Input with the queried string as a single parameter and partially correct postal code:
https://api.kartes.lv/v3/KVDM_jb1kd/ext-geocoding?street=daugavpils%20%2022%20sloka&postalcode=2020&maxresults=1
Output:
<LocationMatch>
<Matching>
<Score>93</Score>
<MatchLevel>houseNumber</MatchLevel>
<MatchingScore>
<City>93</City>
<Street>93</Street>
<HouseNumber>93</HouseNumber>
<Country>100</Country>
</MatchingScore>
<MatchType>pointAddress</MatchType>
</Matching>
<Location>
<MapLocationId>c3f402b02256bea19c0a3bd68a34916b</MapLocationId>
<LocationType>address</LocationType>
<DisplayCoordinate>
<Latitude>56.942235</Latitude>
<Longitude>23.608701</Longitude>
</DisplayCoordinate>
<NavigationCoordinate>
<Latitude>56.942152</Latitude>
<Longitude>23.608809</Longitude>
</NavigationCoordinate>
<Address>
<Label>Daugavpils iela 22, Jūrmala, Latvija</Label>
<Country>LV</Country>
<County>Jūrmala</County>
<City>Jūrmala</City>
<District/>
<Street>Daugavpils iela</Street>
<HouseNumber>22</HouseNumber>
<PostalCode>2011</PostalCode>
<AdditionalData key="CountryName">Latvija</AdditionalData>
<AdditionalData key="CountyName">Jūrmala</AdditionalData>
</Address>
</Location>
</LocationMatch>
Use examples
Defining an extended geocoding API class in JavaScript code:
class ExtendedGeocodingApi {
constructor() {
this.apiKey = 'your_api_key_here'; // Replace with your actual API key
this.baseUrl = 'https://api.kartes.lv/v3';
}
// Method to fetch extended geocoded data
async getExtendedGeocodingData({city, postalcode, street, housenumber, maxresults = 1}) {
const params = new URLSearchParams({
city: city,
postalcode: postalcode,
street: street,
housenumber: housenumber,
maxresults: maxresults
});
const url = `${this.baseUrl}/${this.apiKey}/ext-geocoding?${params.toString()}`;
try {
const response = await fetch(url);
// Check if the response is ok (status code 200-299)
if (!response.ok) {
throw new Error(`Error fetching data: ${response.statusText}`);
}
const data = await response.json();
return { success: true, data };
} catch (error) {
console.error('Fetch error:', error);
return { success: false, error: error.message };
}
}
}
Using the extended geocoding API class:
const api = new ExtendedGeocodingAPI();
api.getExtendedGeocodingData({city: 'Rīga', postalcode: '1020', street: 'Krasta iela', housenumber: '105A', maxresults = 1})
.then(result => {
if (!result.success) {
console.error('Error:', result.error); // Handle the error
return;
}
console.log(result.data);
// Use the data
});