当前位置: 首页 > news >正文

使用Python创建省份城市地图选择器

在这篇博客中,我们将探讨如何使用Python创建一个简单而实用的省份城市地图选择器。这个项目不仅能帮助我们学习Python的基础知识,还能让我们了解如何处理JSON数据和集成网页浏览器到桌面应用程序中。
C:\pythoncode\new\geographicgooglemap.py

全部代码

import wx
import wx.html2
import jsonclass MapSelector(wx.Frame):def __init__(self):super().__init__(parent=None, title='省份城市地图选择器')panel = wx.Panel(self)# 加载省份和城市数据with open('area-city.json', 'r', encoding='utf-8') as f:self.data = json.load(f)# 创建控件self.province_cb = wx.ComboBox(panel, choices=[p['name'] for p in self.data], style=wx.CB_READONLY)self.city_cb = wx.ComboBox(panel, style=wx.CB_READONLY)self.confirm_btn = wx.Button(panel, label='确定')self.browser = wx.html2.WebView.New(panel)# 绑定事件self.province_cb.Bind(wx.EVT_COMBOBOX, self.on_province_select)self.confirm_btn.Bind(wx.EVT_BUTTON, self.on_confirm)# 设置布局sizer = wx.BoxSizer(wx.VERTICAL)sizer.Add(self.province_cb, 0, wx.ALL | wx.EXPAND, 5)sizer.Add(self.city_cb, 0, wx.ALL | wx.EXPAND, 5)sizer.Add(self.confirm_btn, 0, wx.ALL | wx.EXPAND, 5)sizer.Add(self.browser, 1, wx.ALL | wx.EXPAND, 5)panel.SetSizer(sizer)self.SetSize(800, 600)def on_province_select(self, event):province = self.province_cb.GetStringSelection()for p in self.data:if p['name'] == province:cities = p['districts']self.city_cb.Clear()self.city_cb.AppendItems([city['name'] for city in cities])breakdef on_confirm(self, event):province = self.province_cb.GetStringSelection()city = self.city_cb.GetStringSelection()if province and city:# 使用高德地图API显示城市地图# url = f"https://www.amap.com/search?query={city}"url = f"https://www.google.com/maps/place/{city}"self.browser.LoadURL(url)if __name__ == '__main__':app = wx.App()frame = MapSelector()frame.Show()app.MainLoop()

项目概述

我们的目标是创建一个应用程序,它具有以下功能:

  1. 从JSON文件加载中国的省份和城市数据
  2. 提供两个下拉框,分别用于选择省份和城市
  3. 当选择一个省份时,自动更新城市下拉框的选项
  4. 点击确定按钮后,在嵌入的网页浏览器中显示所选城市的高德地图

技术栈

  • Python 3.x
  • wxPython:用于创建图形用户界面
  • wxPython的webview扩展:用于嵌入网页浏览器
  • JSON:用于存储和处理省份和城市数据

实现步骤

1. 数据准备

首先,我们需要准备一个包含省份和城市信息的JSON文件。文件结构如下:

[{"name": "省份名称","districts": [{"name": "城市名称","center": "经度,纬度"},// 更多城市...]},// 更多省份...
]

2. 创建GUI

使用wxPython,我们创建了一个包含两个下拉框(ComboBox)、一个按钮和一个网页浏览器控件的窗口。

3. 加载数据

在程序初始化时,我们从JSON文件中加载省份和城市数据。

4. 实现交互逻辑

  • 当选择一个省份时,更新城市下拉框的选项。
  • 当点击确定按钮时,在网页浏览器中加载所选城市的高德地图。

核心代码

以下是实现这个项目的核心Python代码:

import wx
import wx.html2
import jsonclass MapSelector(wx.Frame):def __init__(self):super().__init__(parent=None, title='省份城市地图选择器')panel = wx.Panel(self)# 加载省份和城市数据with open('area-city.json', 'r', encoding='utf-8') as f:self.data = json.load(f)# 创建控件self.province_cb = wx.ComboBox(panel, choices=[p['name'] for p in self.data], style=wx.CB_READONLY)self.city_cb = wx.ComboBox(panel, style=wx.CB_READONLY)self.confirm_btn = wx.Button(panel, label='确定')self.browser = wx.html2.WebView.New(panel)# 绑定事件self.province_cb.Bind(wx.EVT_COMBOBOX, self.on_province_select)self.confirm_btn.Bind(wx.EVT_BUTTON, self.on_confirm)# 设置布局sizer = wx.BoxSizer(wx.VERTICAL)sizer.Add(self.province_cb, 0, wx.ALL | wx.EXPAND, 5)sizer.Add(self.city_cb, 0, wx.ALL | wx.EXPAND, 5)sizer.Add(self.confirm_btn, 0, wx.ALL | wx.EXPAND, 5)sizer.Add(self.browser, 1, wx.ALL | wx.EXPAND, 5)panel.SetSizer(sizer)self.SetSize(800, 600)def on_province_select(self, event):province = self.province_cb.GetStringSelection()for p in self.data:if p['name'] == province:cities = p['districts']self.city_cb.Clear()self.city_cb.AppendItems([city['name'] for city in cities])breakdef on_confirm(self, event):province = self.province_cb.GetStringSelection()city = self.city_cb.GetStringSelection()if province and city:url = f"https://www.amap.com/search?query={city}"self.browser.LoadURL(url)if __name__ == '__main__':app = wx.App()frame = MapSelector()frame.Show()app.MainLoop()

运行项目

要运行这个项目,您需要:

  1. 安装必要的Python库:

    pip install wxPython
    pip install wxPython-webview
    
  2. 准备 ‘area-city.json’ 文件,确保它与Python脚本在同一目录下。

  3. 运行Python脚本。

效果如下

在这里插入图片描述

相关链接

https://github.com/nicez2/china-area-json/blob/master/area-city.json
https://github.com/nicez2/china-area-json/blob/master/area-province.json

总结

通过这个项目,我们学习了:

  1. 如何使用wxPython创建基本的图形用户界面
  2. 如何处理JSON数据
  3. 如何在wxPython应用中嵌入网页浏览器
  4. 如何实现简单的用户交互逻辑

这个项目为更复杂的地理信息应用程序奠定了基础。您可以进一步扩展它,例如添加更多的地理信息,实现地图标记功能,或者集成其他地图API。

相关文章:

使用Python创建省份城市地图选择器

在这篇博客中,我们将探讨如何使用Python创建一个简单而实用的省份城市地图选择器。这个项目不仅能帮助我们学习Python的基础知识,还能让我们了解如何处理JSON数据和集成网页浏览器到桌面应用程序中。 C:\pythoncode\new\geographicgooglemap.py 全部代码…...

【Java 数据结构】Stack和Queue介绍

Stack和Queue StackStack是什么Stack的使用构造方法常用方法 栈的模拟实现初始化和基本方法入栈出栈查看栈顶 栈的应用链栈的简单介绍 QueueQueue是什么Queue的使用队列的模拟实现初始化入队出队查看队头元素 循环队列循环队列的定义及其注意点循环队列的实现初始化和基本方法获…...

Docker基本语法

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、更新yum镜像仓库(一)查看本地yum镜像源地址(二)设置docker的镜像仓库(1)安装必要工具…...

uniapp 对于scroll-view滑动和页面滑动的联动处理

需求 遇到一个需求 解决方案 这个时候可以做一个内页面滑动判断 <!-- scroll-y 做true或者false的判断是否滑动 --> <view class"u-menu-wrap" style"background-color: #fff;"><scroll-view :scroll-y"data.isGo" scroll-wit…...

opencv基础的图像操作

1.读取图像&#xff0c;显示图像&#xff0c;保存图像 #图像读取、显示与保存 import numpy as np import cv2 imgcv2.imread(./src/1.jpg) #读取 cv2.imshow("img",img) #显示 cv2.imwrite("./src/2.jpg",img) #保存 cv2.waitKey(0) #让程序进入主循环(让…...

Java | Leetcode Java题解之第337题打家劫舍III

题目&#xff1a; 题解&#xff1a; class Solution {public int rob(TreeNode root) {int[] rootStatus dfs(root);return Math.max(rootStatus[0], rootStatus[1]);}public int[] dfs(TreeNode node) {if (node null) {return new int[]{0, 0};}int[] l dfs(node.left);i…...

本地查看的Git远程仓库分支与远程仓库分支数量不一致

说明&#xff1a;一次&#xff0c;在IDEA中想切换到某分支&#xff0c;但是查看Remote没有找到要切换的分支&#xff0c;但是打开GitLab&#xff0c;查看远程仓库&#xff0c;是有这个分支的。 解决&#xff1a;1&#xff09;在IDEA的Git中&#xff0c;点下面Fatch获取一下远程…...

opencv-python实战项目九:基于拉普拉斯金字塔的图像融合

文章目录 一&#xff0c;简介&#xff1a;二&#xff0c;拉普拉斯金字塔介绍&#xff1a;三&#xff0c;算法实现步骤3.1 构建融合拉普拉斯金字塔3.2 融合后的拉普拉斯金字塔复原&#xff1a; 四&#xff0c;整体代码实现&#xff1a;五&#xff0c;效果&#xff1a; 一&#x…...

浅谈JDK

JDK(Java Development Kit) JDK是Java开发工具包&#xff0c;是Java编程语言的核心软件开发工具。 JDK包含了一系列用于开发、编译和运行Java应用程序的工具和资源。其中包括&#xff1a; 1.Java编译器&#xff08;javac&#xff09;&#xff1a;用于将Java源代码编译成字节…...

爬虫案例3——爬取彩票双色球数据

简介&#xff1a;个人学习分享&#xff0c;如有错误&#xff0c;欢迎批评指正 任务&#xff1a;从500彩票网中爬取双色球数据 目标网页地址&#xff1a;https://datachart.500.com/ssq/ 一、思路和过程 目标网页具体内容如下&#xff1a; ​​​​​ 我们的任务是将上图中…...

C++ | Leetcode C++题解之第337题打家劫舍III

题目&#xff1a; 题解&#xff1a; struct SubtreeStatus {int selected;int notSelected; };class Solution { public:SubtreeStatus dfs(TreeNode* node) {if (!node) {return {0, 0};}auto l dfs(node->left);auto r dfs(node->right);int selected node->val…...

软件架构设计师-UML知识导图

软件架构设计师-UML知识导图&#xff0c;包含如下内容&#xff1a; 结构化设计&#xff0c;包含结构化设计的概念、结构化设计的主要内容、概要设计、详细设计及模块设计原则&#xff1b;UML是什么&#xff1a;介绍UML是什么&#xff1b;UML的结构&#xff1a;构造块、公共机制…...

在使用transformers和pytorch时出现的版本冲突的问题

在使用transformers和torch库的时候&#xff0c;出现了以下问题&#xff1a; 1、OSError: [WinError 126] 找不到指定的模块。 Error loading "D:\Program Files\anaconda3\envs\testenv\Lib\site-packages\torch\lib\fbgemm.dll" or one of its dependencies. 2、…...

uniapp粘贴板地址识别

1&#xff1a; 插件安装 主要是依靠 address-parse 这个插件&#xff1a; 官网 收货地址自动识别 支持pc、h5、微信小程序 - DCloud 插件市场 // 首先需要引入插件 npm install address-parse --save 2&#xff1a;html部分 <view class""><view class&quo…...

C语言 | Leetcode C语言题解之第335题路径交叉

题目&#xff1a; 题解&#xff1a; bool isSelfCrossing(int* distance, int distanceSize){if (distance NULL || distanceSize < 4) {return false;}for (int i 3; i < distanceSize; i) {if ((distance[i] > distance[i - 2]) && (distance[i - 1] &l…...

TypeScript学习第十三篇 - 泛型

在编译期间不确定变量的类型&#xff0c;在调用时&#xff0c;由开发者指定具体的类型。 1. 如何给arg参数和函数指定类型&#xff1f; function identity(arg){return arg; }identity(1) identity(jack) identity(true) identity([]) identity(null)定义的时候&#xff0c;无…...

工业智能网关在汽车制造企业的应用价值及功能-天拓四方

随着工业互联网的飞速发展&#xff0c;工业智能网关作为连接物理世界与数字世界的桥梁&#xff0c;正逐渐成为制造业数字化转型的核心组件。本文将以一家汽车制造企业的实际使用案例为蓝本&#xff0c;深入解析工业智能网关在实际应用中的价值、功能及其实操性。 一、背景与挑…...

LLM - 在服务器中使用 Ollama + OpenWebUI 部署最新大模型

欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/140992533 免责声明:本文来源于个人知识与公开资料,仅用于学术交流,欢迎讨论,不支持转载。 Ollama 是一个开源的大型语言模型(LLM)服务工具,目的是简化本地运行…...

重启人生计划-积蓄星火

&#x1f973;&#x1f973;&#x1f973; 茫茫人海千千万万&#xff0c;感谢这一刻你看到了我的文章&#xff0c;感谢观赏&#xff0c;大家好呀&#xff0c;我是最爱吃鱼罐头&#xff0c;大家可以叫鱼罐头呦~&#x1f973;&#x1f973;&#x1f973; 如果你觉得这个【重启人生…...

2024.08.11 校招 实习 内推 面经

地/球&#x1f30d; &#xff1a; neituijunsir 交* 流*裙 &#xff0c;内推/实习/校招汇总表格 1、自动驾驶一周资讯 - 比亚迪将采购华为智驾系统&#xff0c;用于方程豹新款越野车&#xff1b;英特尔发布第一代车载独立显卡&#xff1b;黑芝麻智能上市首日破发大跌 自动…...

LCA(Lowest Common Ancestor)

LCA&#xff08;Lowest Common Ancestor&#xff09; 定义 在树上取两点 x,yx,y&#xff0c;他们的 LCA 为距离他们最近的公共祖先。 本章主要讲的是倍增求 LCA。 暴力求取 从 xx 开始向上移动到根结点&#xff0c;并标记沿途结点。从 yy 开始向上移动到根结点&#xff0c…...

张钹院士:大模型时代的企业AI发展趋势

在当今技术迅速发展的时代&#xff0c;生成式人工智能与大模型正成为推动产业变革的重要力量。随着AI技术的不断成熟与普及&#xff0c;它的应用已从个人领域扩展至企业层面&#xff0c;广泛覆盖各行各业。 那么&#xff0c;新技术究竟会给产业带来哪些积极地影响&#xff1f;…...

php连接sphinx的长连接事宜以及sphinx的排除查询以及关于sphinx里使用SetSelect进行复杂的条件过滤或复杂查询

一、php连接sphinx的长连接事宜以及sphinx的排除查询 在使用php连接sphinx时&#xff0c;默认的sphinx连接非长连接&#xff0c;于是在想php连接sphinx能否进行一些优化 publish:January 9, 2018 -Tuesday: 方法&#xff1a;public bool SphinxClient::open ( void ) — 建立到…...

抓包分析排查利器TCPdump

tcpdump命令介绍与常规用法。 基础命令介绍 # 固定语法 -i 指定网卡名称 -nn 显示IP地址 -w 指定输出的文件名称 tcpdump -i eth0 -nn -w test.cap-nn 不把主机的网络地址与协议转换成名字 -w 把数据包数据写入指定的文件 and 连接参数 host 指明主机 port 指明端口 src 源IP…...

八种排序算法的复杂度(C语言)

归并排序(递归与非递归实现,C语言)-CSDN博客 快速排序(三种方法,非递归快排,C语言)-CSDN博客 堆排序(C语言)-CSDN博客 选择排序(C语言)以及选择排序优化-CSDN博客 冒泡排序(C语言)-CSDN博客 直接插入排序(C语言)-CSDN博客 希尔排序( 缩小增量排序 )(C语言)-CSDN博客 计数…...

docker compose部署rabbitmq集群,并使用haproxy负载均衡

一、创建rabbitmq的data目录 mkdir data mkdir data/rabbit1 mkdir data/rabbit2 mkdir data/rabbit3 二、创建.erlang.cookie文件&#xff08;集群cookie用&#xff09; echo "secretcookie" > .erlang.cookie 三、创建haproxy.cfg配置文件 global log stdout fo…...

git强制推送代码教程

git强制推送代码教程 首先说明情况&#xff0c;我的代码remote了两个git库&#xff0c;现在想要推送到其中一个&#xff0c;但是版本不对&#xff0c;被拒绝&#xff0c;因此下面将进行强制推送 首先检查远程库都有哪些 git remote -v2. 检查当前的分支 git branch当前分支前…...

windows C++-高级并发和异步(三)

深入了解 winrt::resume_foreground(下) 调用 winrt::resume_foreground 时会始终先排队&#xff0c;然后展开堆栈。 也可选择设置恢复优先级。 winrt::fire_and_forget RunAsync(DispatcherQueue queue) {...co_await winrt::resume_foreground(queue, DispatcherQueuePrior…...

河北移动:核心系统数据库成功完成整体迁移 ,实现全栈国产|OceanBase案例

本文作者&#xff1a;移动通信集团河北有限公司架构规划专家&#xff0c;房瑞 项目背景&#xff1a; 中国移动通信集团河北有限公司一直在积极响应国家及集团的号召&#xff0c;以磐舟&磐基云原生为底座&#xff0c;结合国产浏览器、中间件、数据库、操作系统和服务器等&a…...

ZKRollup

目录 ZKRollup 基本概念 运作原理 特点与优势 应用场景 典型项目 ZKRollup ZKRollup,全称为Zero-Knowledge Rollup,是一种基于零知识证明的二层扩容方案(Layer 2)。它旨在通过提高交易处理效率和降低交易成本来扩展区块链网络的能力,尤其是在以太坊等区块链平台上得…...

服装定制属于什么行业/广州seo网络推广员

题目1&#xff1a; 查找最晚入职员工的所有信息 CREATE TABLE ‘employees’ ( ‘emp_no’ int(11) NOT NULL, ‘birth_date’ date NOT NULL, ‘first_name’ varchar(14) NOT NULL, ‘last_name’ varchar(16) NOT NULL, ‘gender’ char(1) NOT NULL, ‘hire_date’ date N…...

厦门做企业网站/免费推广网站大全

最短路问题需要记录路径时&#xff0c;可以另外开一个数组记录从哪个点走过来的。如果需要找出多条长度一样的最短路径&#xff0c;可以类似邻接链表的形式记录被更新的点&#xff0c;最后用dfs搜索。a * b % mod a % mod * b % mod乘法运算时要注意是否超上限long long类型最…...

潍坊中小型网站建设公司/关键词搜索引擎工具爱站

支持嵌套子报表直接编辑保存&#xff0c;多个子报表同一时候存储在一个报表格式文件中&#xff0c;设计更简便&#xff0c;避免了嵌套报表的多个报表格式载入。新增经常使用边距设置图片控件支持【保存宽高比】设置等。调整多项功能修复多个BUG相关链接MyReport演示、产品站点相…...

php网站开发师条件/重庆人力资源和社会保障网官网

Akaxin是一款开源免费的私有聊天软件&#xff0c;可以部署在任意服务器上&#xff0c;搭建自己的聊天服务器&#xff0c;供自己与朋友、用户使用。githubhttps://github.com/daychat/openzaly特性&#xff1a;单聊、群聊(含文字、图片、语音等)端到端的加密消息(服务端不可解密…...

品牌网站案例/网店推广运营策略

问题 在JDK 5之前Java语言是靠synchronized关键字保证同步的&#xff0c;这会导致有锁 锁机制存在以下问题&#xff1a; &#xff08;1&#xff09;在多线程竞争下&#xff0c;加锁、释放锁 会导致比较多的 上下文切换 和 调度延时&#xff0c;引起性能问题。 &#xff0…...

如何做网站url优化/外贸网站优化推广

第二天 暂时先把显示搞出来了&#xff0c;虽然是测试例子&#xff0c;但是改一改代码应该可以显示调试结果&#xff0c;所以先放着&#xff0c;搞一搞模型移植吧。 目标&#xff1a;移植自己训练的Resnet18-SSD的模型到3559上 1、按照文档配置SDK环境 我觉得文档太长&#x…...