利用高德API获取整个城市的公交路线并可视化(四)

2024-09-05 22:36

本文主要是介绍利用高德API获取整个城市的公交路线并可视化(四),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

副标题:公共汽电车站点覆盖率——以厦门市公交线路为例

书接上回,我们有了公交的线路、站点数据,并同时对数据质量进行了校验,但是不同城市情况不同,需要看当地对公交交通数据的开放程度,部分城市建设的有大数据平台,也可以检索到公共交通的一些标签数据,这篇文章我们来讨论一下公交覆盖率;

公交数据获取方式参考我上篇文章:利用高德API获取整个城市的公交路线并可视化(三)-CSDN博客

首先先根据行政区把在范围内的公交站点裁剪出来,最新2024年的行政区边界参考我发布的这个数据:【免费】2024全国行政区边界(省、市、县)_莫兰指数资源-CSDN文库,本文大部分操作由arcgispro进行演示,arcgis操作步骤大致一致;

因为我们拿到是数据是高德坐标系(GCJ-02)我们需要先转成WGS84地理坐标系,批量坐标转换这里就不再赘述,移步至往期文章,再投影成WGS 1984 Web Mercator (auxiliary sphere) 投影坐标系

接下来就是创建缓冲区,参考国家发布的公共汽电车线网评价指标标准,一般选取300m或者500m,本文以500m为例,进行计算;

方法选择平面,平面用的是欧氏距离,融合选项选择全部,在arcgis中选择ALL,目的是使得叠加的站点缓冲区平面不会被反复计算,大部分公交站都是被多条线经停的,因为在点集成线的过程中需要保值每条线都要有这个站,那生成面是时候就自然这个站点的位置生成多个空间上叠加的面域,但是平面图是看不出来的 ,所以这一步骤通过融合将该站多个面域进行合并;

当然也可以用创建泰森多边形的方法,来切分每个站点不重叠的辐射范围,并且优化展示效果;

生成的结果图层与融合缓冲区图层进行【相交】即可,需要详细步骤的可以移步到我这篇文章:

ArcGIS应用指南:生成泰森多边形的缓冲区_交通站点以缓冲区范围结合泰森多边形形成的区域共同界定站域边界-CSDN博客

接下来就是计算缓冲区面积,单位选择平方千米,坐标系选取前面的投影坐标系,有需要也可以改成自己常用的坐标系,如国家2000等;

接着我们讨论一个比较复杂的问题,就是我们如何实现多对多裁剪,为什么讨论多对多裁剪呢,因为到这里我们的行政区属性表和融合面的属性表都是多个面层,我们需要计算多个行政区内的公交覆盖率,那就需要把那些跨几个行政区的面裁剪成几部分,比如下面这张图,这个面就比较调气横跨两个行政区;

那我们如何把每个行政区对应每个融合面呢,argis似乎并没有合适的工具解决这个问题,那需要我们把问题转化,把多对多的问题,再次转化为多对一,先看我们的聚集点,就是覆盖率,所以我们把所有的面合并成一个图层,再由行政区进行裁剪,这个问题就迎刃而解了;

这里把站点500m覆盖率不重叠部分融合成一张表,再由行政区进行分割,分割要素选择''行政区'',分割字段选择''县名'',这里需要建一个文件地理数据库,也就是.gdb文件,需要把分割的文件导入这个文件地理数据库;

然后我们根据数据保存的.gdb的文件路径,打开就可以找到他们;

我们可以看到每个面都被分割开了,PS:如果需要生成融合面的时候不产生多个面层,可以把厦门市行政区合成一个完整的面就不会出现上述问题了,也自然不需要这一步了

接下来,就是我们的看图说话环节,乍看之下,我们看到湖里区和思明区的公交覆盖率很高,因为拿不到厦门市的用地规划数据,所以我们退而求其次,结合厦门经济特区年鉴-2023里面的湖里区和思明区国土面积来做计算,数据来源:厦门经济特区年鉴-2023-框架 - Computer Generated Web Page (xm.gov.cn)

截止2022年末,湖里区和思明区的国土面积为156.09平方千米,因为指标统计的是建成区面积,所以实际值是比这个小的,但即使如此公交500m覆盖率也有75%,可见这两个区的公交站点设置率普之高,表明这两个区的公共交通系统较为发达,居民出行便利度较高;

文章仅用于分享个人学习成果与个人存档之用,分享知识,如有侵权,请联系作者进行删除。所有信息均基于作者的个人理解和经验,不代表任何官方立场或权威解读。

这篇关于利用高德API获取整个城市的公交路线并可视化(四)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大

如何更优雅地对接第三方API

如何更优雅地对接第三方API 本文所有示例完整代码地址:https://github.com/yu-linfeng/BlogRepositories/tree/master/repositories/third 我们在日常开发过程中,有不少场景会对接第三方的API,例如第三方账号登录,第三方服务等等。第三方服务会提供API或者SDK,我依稀记得早些年Maven还没那么广泛使用,通常要对接第三方

Python:豆瓣电影商业数据分析-爬取全数据【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】

**爬取豆瓣电影信息,分析近年电影行业的发展情况** 本文是完整的数据分析展现,代码有完整版,包含豆瓣电影爬取的具体方式【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】   最近MBA在学习《商业数据分析》,大实训作业给了数据要进行数据分析,所以先拿豆瓣电影练练手,网络上爬取豆瓣电影TOP250较多,但对于豆瓣电影全数据的爬取教程很少,所以我自己做一版。 目

Java基础回顾系列-第五天-高级编程之API类库

Java基础回顾系列-第五天-高级编程之API类库 Java基础类库StringBufferStringBuilderStringCharSequence接口AutoCloseable接口RuntimeSystemCleaner对象克隆 数字操作类Math数学计算类Random随机数生成类BigInteger/BigDecimal大数字操作类 日期操作类DateSimpleDateForma

JS和jQuery获取节点的兄弟,父级,子级元素

原文转自http://blog.csdn.net/duanshuyong/article/details/7562423 先说一下JS的获取方法,其要比JQUERY的方法麻烦很多,后面以JQUERY的方法作对比。 JS的方法会比JQUERY麻烦很多,主要则是因为FF浏览器,FF浏览器会把你的换行也当最DOM元素。 <div id="test"><div></div><div></div

Restful API 原理以及实现

先说说API 再说啥是RESRFUL API之前,咱先说说啥是API吧。API大家应该都知道吧,简称接口嘛。随着现在移动互联网的火爆,手机软件,也就是APP几乎快爆棚了。几乎任何一个网站或者应用都会出一款iOS或者Android APP,相比网页版的体验,APP确实各方面性能要好很多。 那么现在问题来了。比如QQ空间网站,如果我想获取一个用户发的说说列表。 QQ空间网站里面需要这个功能。

京东物流查询|开发者调用API接口实现

快递聚合查询的优势 1、高效整合多种快递信息。2、实时动态更新。3、自动化管理流程。 聚合国内外1500家快递公司的物流信息查询服务,使用API接口查询京东物流的便捷步骤,首先选择专业的数据平台的快递API接口:物流快递查询API接口-单号查询API - 探数数据 以下示例是参考的示例代码: import requestsurl = "http://api.tanshuapi.com/a

vcpkg子包路径批量获取

获取vcpkg 子包的路径,并拼接为set(CMAKE_PREFIX_PATH “拼接路径” ) import osdef find_directories_with_subdirs(root_dir):# 构建根目录下的 "packages" 文件夹路径root_packages_dir = os.path.join(root_dir, "packages")# 如果 "packages"