python经纬度批量标点_Python利用百度地图api批量获取地址经纬度

1.pip安装xlrd,xlwt,requests模块.

2.在工程目录处放置地点Excel文件。

python代码:

#coding:utf-8

import xlrd

import xlwt

import requests

import urllib

import math

import re

pattern_x = re.compile(r‘"x":(".+?")‘)

pattern_y = re.compile(r‘"y":(".+?")‘)

def mercator2wgs84(mercator):

# key1=mercator.keys()[0]

# key2=mercator.keys()[1]

point_x = mercator[0]

point_y = mercator[1]

x = point_x / 20037508.3427892 * 180

y = point_y / 20037508.3427892 * 180

y = 180 / math.pi * (2 * math.atan(math.exp(y * math.pi / 180)) - math.pi / 2)

return (x, y)

def get_mercator(addr):

quote_addr = urllib.quote(addr.encode(‘utf8‘))

city = urllib.quote(u‘兰州市‘.encode(‘utf8‘))

province = urllib.quote(u‘甘肃省‘.encode(‘utf8‘))

if quote_addr.startswith(city) or quote_addr.startswith(province):

pass

else:

quote_addr = quote_addr

s = urllib.quote(u‘北京市‘.encode(‘utf8‘))

api_addr = "http://api.map.baidu.com/?qt=gc&wd=%s&cn=%s&ie=utf-8&oue=1&fromproduct=jsapi&res=api&callback=BMap._rd._cbk62300" % (

quote_addr

, s)

req = requests.get(api_addr)

content = req.content

x = re.findall(pattern_x, content)

y = re.findall(pattern_y, content)

if x:

x = x[0]

y = y[0]

x = x[1:-1]

y = y[1:-1]

x = float(x)

y = float(y)

location = (x, y)

else:

location = ()

return location

def run():

data = xlrd.open_workbook(‘Book2.xlsx‘)

rtable = data.sheets()[0]

nrows = rtable.nrows

values = rtable.col_values(0)

workbook = xlwt.Workbook()

wtable = workbook.add_sheet(‘data‘, cell_overwrite_ok=True)

row = 0

for value in values:

mercator = get_mercator(value)

if mercator:

wgs = mercator2wgs84(mercator)

else:

wgs = (‘NotFound‘, ‘NotFound‘)

print "%s,%s,%s" % (value, wgs[0], wgs[1])

wtable.write(row, 0, value)

wtable.write(row, 1, wgs[0])

wtable.write(row, 2, wgs[1])

row = row + 1

workbook.save(‘data.xls‘)

if __name__ == ‘__main__‘:

run()

运行即可得到data.xls结果文件。

原文:http://www.cnblogs.com/reboot777/p/7124010.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
利用Python和高德地图API实现经纬度地址批量转换是可行的。首先,我们需要准备高德地图的API密钥,该密钥可以通过高德地图开发者平台申请获得。 接下来,我们可以使用Python中的requests库发送HTTP请求,通过调用高德地图的逆地理编码接口,将经纬度转换为地址。我们需要将API密钥和待转换的经纬度构建为合适的URL,并发送GET请求。高德地图API将返回JSON格式的数据,其中包含有关地址信息的详细内容。 在代码中,我们可以使用for循环来遍历经纬度的列表,对每个经纬度调用逆地理编码接口并解析返回的JSON数据。我们可以从返回的数据中提取出地址信息,并将其保存到一个新的CSV文件中。 以下是一个简单的示例代码: ```python import requests import csv api_key = "your_api_key" def get_address(lat, lng): url = f"https://restapi.amap.com/v3/geocode/regeo?key={api_key}&location={lng},{lat}&radius=1000&extensions=all&batch=true&roadlevel=1" response = requests.get(url) data = response.json() address = data['regeocodes'][0]['formatted_address'] return address def main(): with open('input.csv', 'r') as input_file, open('output.csv', 'w', newline='') as output_file: reader = csv.reader(input_file) writer = csv.writer(output_file) writer.writerow(['经度', '纬度', '地址']) for row in reader: lat, lng = row[0], row[1] address = get_address(lat, lng) writer.writerow([lat, lng, address]) print("地址转换完成!") if __name__ == '__main__': main() ``` 在这个示例中,我们假设输入文件是一个CSV文件,其中包含经纬度数据。我们将转换后的地址保存到新的CSV文件中,其中包含经度、纬度和地址信息。 通过运行这个Python脚本,我们可以批量转换经纬度地址,并将结果保存到输出文件中。这样,我们就可以在后续的工作中方便地使用地址信息了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值