python+pandas 从 excel中地址批量获取经纬度后写入excel

# -- coding:utf-8 --
import pandas as pd
import requests

ak_str='j6F1ZAGzwya*****56YP'  #百度地图开放平台AK

def get_position(name,AK):
    url = f'http://api.map.baidu.com/geocoding/v3/?address={name}&output=json&ak={AK}'
    res = requests.get(url)  
    val = res.json()
    retval = {'地址': name,
              '经度': val['result']['location']['lng'],
              '维度': val['result']['location']['lat'],
              }
    longitude = retval['经度']
    latitude = retval['维度']
    return longitude, latitude

# 获取地理信息
dataSet = pd.read_excel("D:\python_file\hangjia.xlsx")
df = dataSet["address"]  #获取excel中地址列数据
df_location = df.apply(get_position,AK=ak_str) #pd apply数据执行 get_position
dataSet["longitude"] = df_location.map(lambda x: x[0]) 
dataSet["latitude"] = df_location.map(lambda x: x[1])
print(dataSet)
dataSet.to_excel("D:\python_file\hangjia.xlsx", index=False,encoding='utf_8_sig')

注意几个坑:

1、requests版本不对,导致出现莫名其妙错误 报requests.get(url)相关错误,多半是这个原因;

2、pip install -U requests 老出错,用 python -m pip install -U requests 解决

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

womode

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值