NAME

Geo::Coder::DataScienceToolkit - Provides a geocoding functionality using http://www.datasciencetoolkit.org/

VERSION

Version 0.02

SYNOPSIS

use Geo::Coder::DataScienceToolkit;

my $geocoder = Geo::Coder::DataScienceToolkit->new();
my $location = $geocoder->geocode(location => '10 Downing St., London, UK');

DESCRIPTION

Geo::Coder::DataScienceToolkit provides an interface to datasciencetoolkit, a free geocode database covering the US and UK.

METHODS

new

$geocoder = Geo::Coder::DataScienceToolkit->new();
my $ua = LWP::UserAgent->new();
$ua->env_proxy(1);
$geocoder = Geo::Coder::DataScienceToolkit->new(ua => $ua);

geocode

$location = $geocoder->geocode(location => $location);

print 'Latitude: ', $location->{'results'}[0]->{'geometry'}->{'location'}->{'lat'}, 38.90, 1e-2); "\n";
print 'Longitude: ', delta_within($location->{'results'}[0]->{'geometry'}->{'location'}->{'lng'}, -77.04, 1e-2); "\n";

@locations = $geocoder->geocode('Portland, USA');
diag 'There are Portlands in ', join (', ', map { $_->{'state'} } @locations);

ua

Accessor method to get and set UserAgent object used internally. You can call env_proxy for example, to get the proxy information from environment variables:

$geocoder->ua()->env_proxy(1);

You can also set your own User-Agent object:

use LWP::UserAgent::Throttled;
$geocoder->ua(LWP::UserAgent::Throttled->new());

reverse_geocode

Reverse geocoding is not supported by datasciencetoolkit.org, so calls to this will generate an error.

AUTHOR

Nigel Horne <njh@bandsman.co.uk>

Based on Geo::Coder::XYZ.

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

Lots of thanks to the folks at DSTK.

SEE ALSO

Geo::Coder::GooglePlaces, HTML::GoogleMaps::V3, http://www.datasciencetoolkit.org/about.

LICENSE AND COPYRIGHT

Copyright 2019 Nigel Horne.

This program is released under the following licence: GPL2