python调用百度地图api,查询地方的经度纬度,将数据写入excel

本文主要是介绍python调用百度地图api,查询地方的经度纬度,将数据写入excel,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一. 内容简介

python调用百度地图api,查询地方的经度纬度,将数据写入excel

二. 软件环境

2.1vsCode

2.2Anaconda

version: conda 22.9.0

三.主要流程

3.1 调用百度地图api,查询地方的经度纬度

先创建账号百度地图API
进去以后先创建账号,账号创建完成以后,点击右上角控制台
在这里插入图片描述
创建应用
在这里插入图片描述
在这里插入图片描述
然后就直接运行我粘贴的代码
贴代码

import requests# 精度维度查找函数
def seekLocation(address):# API的URLurl = 'http://api.map.baidu.com/geocoding/v3/'# 构建请求参数params = {'ak': '这块要换成自己的ak的','output': 'json','address': '南京航空航天大学',  # 替换为您要查询的地方名称}params['address'] = address# 发送GET请求response = requests.get(url, params=params)# 检查响应状态码if response.status_code == 200:# 解析返回的JSON数据data = response.json()# 检查结果状态if data['status'] == 0:# 提取经度和纬度location = data['result']['location']return locationelse:print('地理编码失败:', data['message'])else:print('请求出错:', response.status_code)location = seekLocation('河南师范大学')
latitude = location['lat']
longitude = location['lng']
# 打印经度和纬度
print('经度:', longitude)
print('纬度:', latitude)

3.2 读excel数据

把对应的列改一下就好了

from openpyxl import load_workbook# 打开Excel文件
workbook = load_workbook(filename='school2.xlsx')# 选择要操作的表单
sheet = workbook['Sheet1']
column_values = []
for column in sheet.iter_cols(min_col=2, max_col=2, values_only=True):column_values.append(column)
print(column_values)

3.3 写excel数据

from openpyxl import load_workbook# 打开Excel文件
workbook = load_workbook(filename='school2.xlsx')
sheet = workbook['Sheet1']
sheet.cell(row=row_index, column=8, value=value)
# 保存 Excel 文件
workbook.save(filename='school2.xlsx')
# 关闭 Excel 文件
workbook.close()

3.4 完整代码

安装包

! pip install openpyxl
! pip install requests

代码

from openpyxl import load_workbook
import requests# 输入学校
def seekLocation(address):# API的URLurl = 'http://api.map.baidu.com/geocoding/v3/'# 构建请求参数params = {'ak': '换成自己的','output': 'json','address': '南京航空航天大学',  # 替换为您要查询的地方名称}params['address'] = address# 发送GET请求response = requests.get(url, params=params)# 检查响应状态码if response.status_code == 200:# 解析返回的JSON数据data = response.json()# 检查结果状态if data['status'] == 0:# 提取经度和纬度location = data['result']['location']return locationelse:print('地理编码失败:', data['message'])else:print('请求出错:', response.status_code)# 读写程序
'''
file:读写的文件
col1:要读哪一列
col2:纬度写入的列
col3:经度度写入的列
'''
def readWrite(file,col1,col2,col3):# 打开Excel文件workbook = load_workbook(filename=file)# 选择要操作的表单sheet = workbook['Sheet1']column_values = []for column in sheet.iter_cols(min_col=col1, max_col=col1, values_only=True):column_values.append(column)row_index = 1# 指定行索引,例如第2行lastLat = 0# 保存上步纬度lastLng = 0# 保存上步精度for value in column_values[0]:if value == None:# 第八列是纬度,sheet.cell(row=row_index, column=col2, value=0)# 第九列是经度sheet.cell(row=row_index, column=col3, value=0)row_index = row_index + 1continuelocation = seekLocation(value)latitude = location['lat']longitude = location['lng']if lastLat == latitude and lastLng == longitude:sheet.cell(row=row_index-1, column=col3+1, value="重复")sheet.cell(row=row_index, column=col3+1, value="重复")lastLat = latitudelastLng = longitude# 打印经度和纬度print("学校:{},经度:{},纬度:{}".format(value, longitude, latitude))# 写入值到指定行列# 第八列是纬度,sheet.cell(row=row_index, column=col2, value=latitude)# 第九列是经度sheet.cell(row=row_index, column=col3, value=longitude)row_index = row_index + 1# 保存 Excel 文件workbook.save(filename=file)# 关闭 Excel 文件workbook.close()print("写入完成!!!")'''
file:读写的文件(文件名字尽量不要中文)
col1:要读哪一列
col2:纬度写入的列
col3:经度度写入的列
'''
file = "school3.xlsx"
col1 = 2
col2 = 8
col3 = 9
readWrite(file,col1,col2,col3)

在这里插入图片描述

这篇关于python调用百度地图api,查询地方的经度纬度,将数据写入excel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/353413

相关文章

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

基于Python实现多语言朗读与单词选择测验

《基于Python实现多语言朗读与单词选择测验》在数字化教育日益普及的今天,开发一款能够支持多语言朗读和单词选择测验的程序,对于语言学习者来说无疑是一个巨大的福音,下面我们就来用Python实现一个这... 目录一、项目概述二、环境准备三、实现朗读功能四、实现单词选择测验五、创建图形用户界面六、运行程序七、

浅析Python中的绝对导入与相对导入

《浅析Python中的绝对导入与相对导入》这篇文章主要为大家详细介绍了Python中的绝对导入与相对导入的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1 Imports快速介绍2 import语句的语法2.1 基本使用2.2 导入声明的样式3 绝对import和相对i

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

Python中配置文件的全面解析与使用

《Python中配置文件的全面解析与使用》在Python开发中,配置文件扮演着举足轻重的角色,它们允许开发者在不修改代码的情况下调整应用程序的行为,下面我们就来看看常见Python配置文件格式的使用吧... 目录一、INI配置文件二、YAML配置文件三、jsON配置文件四、TOML配置文件五、XML配置文件

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据

《mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据》文章主要介绍了如何从.frm和.ibd文件恢复MySQLInnoDB表结构和数据,需要的朋友可以参... 目录一、恢复表结构二、恢复表数据补充方法一、恢复表结构(从 .frm 文件)方法 1:使用 mysq

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

golang获取prometheus数据(prometheus/client_golang包)

《golang获取prometheus数据(prometheus/client_golang包)》本文主要介绍了使用Go语言的prometheus/client_golang包来获取Prometheu... 目录1. 创建链接1.1 语法1.2 完整示例2. 简单查询2.1 语法2.2 完整示例3. 范围值