-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgeolocaliza.py
56 lines (51 loc) · 1.55 KB
/
geolocaliza.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# -*- coding:utf-8 -*-
"""
Script para geolocalizar endereços
requer o modulo geopy para funcionar:
easy_install geopy
"""
from geopy import geocoders
def carrega_csv(filename)
"""
Abre Arquivo csv com endereços para geo-referenciamento
primeira linha deve ser cabeçalho com nomes de variaveis
"""
with open(filename,'r') as f:
ends = f.readlines()
return ends
def georeferencia(enderecos,arqsaida,campo,geoserv='google'):
if geoserv == 'google':
# Usando o Google
g = geocoders.Google('ABQIAAAA_gnHK6RUKt_B9h1XlCw2fRRSj27_XPuJ4H5ID33wYOhGVNZE9hSv8VlUSRnLRlA9aUnXiquLb89oJw')
elif geoserv == 'geonames':
#Usando o geonames que não requer API Key
gn = geocoders.GeoNames()
j=1
varnames = enderecos.pop(0)
try:
for i,e in enumerate(enderecos):
if i == 0:
fs.write('lat,lng,ATIVIDADE,DDD,T1,NOME,CNPJ,LOGR,NR,COMPL ,CEP,BAIRRO ,CIDADE ,UF,RA,GRUPO,QTD_FUNC\n')
continue
# lat lng perto do RJ ---> agua!
lat = -23.40
lng = -43.10
l = e.split(',')
#por endereco
query_string = '%s, %s, %s, rio de janeiro, RJ, Brazil'%(l[5], l[6], l[9])
#por CEP
#query_string = 'rio de janeiro, RJ, %s, Brazil'%(l[8][:5]+'-'+l[8][5:])
#print query_string#place, lat, lng
try:
place, (lat, lng) = g.geocode(query_string)
print i#place, lat, lng
except:
print '==> Não encontrei no Google: %s'%query_string, j
j += 1
l = [str(lat),str(lng)]+l
fs.write(','.join(l))
finally:
fs.close()
if __name__=="__main__":
fs = open('NovaAmostra-loc-endereco.csv','w')
ends = carrega_csv('Dados nova amostra.csv')