百度坐标、火星坐标与WGS-84坐标转换(纠偏加偏)工具及其开发思路

一、杂言

二、正题

注意:开发过程中坐标单位均为十进制度

转换方法如下:

       BD_to_HX:百度转火星
       BD_to_GG:百度转谷歌(WGS84)
       HX_to_BD:火星转百度
       HX_to_GG:火星转谷歌(WGS84)
       GG_to_BD:谷歌(WGS84)转百度
       GG_to_HX:谷歌(WGS84)转火星

(一)ArcGIS环境下开发Toolbox工具箱

在软件的计算代码使用GitHub开源代码,提供者为wandergis,地址为(GitHub – wandergis/coordTransform_py: 提供百度坐标系(bd-09)、火星坐标系(国测局坐标系、gcj02)、WGS84坐标系直接的坐标互转,也提供了解析高德地址的方法的python版本)。我对代码修改优化,刚开始在ArcGIS平台进行开发,主要为Toolbox工具箱开发,开发成果只要为三类:坐标转换工具矢量版Toolbox、坐标转换工具Excel版Toolbox、坐标转换工具CSV版Toolbox,三类工具均进行过优化与测试,力求达到最精简界面实现工具功能。下面对三类工具进行简要说明:

1、坐标转换工具矢量版Toolbox v1.1(2019-07-29),该版本修复v1.0中部分bug,增加对孔洞孤岛、多部件要素支持。主要功能利用Arcpy游标函数或Arcpy.da游标函数实现点、线、面矢量数据的转换,主要思路:点要素最简单,直接获取坐标转换保存为新点要素;线要素与面要素较为复杂,我在开发中强制将原要素变为单部件要素,然后获取构成线或面要素的点集坐标转换后逆向构造线或面要素,最后保存为新要素。以上均保持原有要素的属性表信息不变。截图:

优点:(1)在ArcGIS环境中,可以调用现有的函数组合,省去逻辑设计消耗脑细胞,同时减少代码书写量;(2)工具界面利用脚本添加到Toolbox中,省去界面脚本编写的烦恼;(3)实现大批量点、线、面矢量数据的转换,保留原始输入要素的属性值,只对组成图形节点的坐标转换与更新。

缺点:ArcGIS运行环境,数据处理效率一般,数据量大会增加处理时间。

2、坐标转换工具Excel版Toolbox,主要功能利用Openpyxl模块读写Excel记录坐标进行转换,该模块仅支持后缀为*.xlsx的文件读写,主要思路:建立Excel文件模板,编写代码读取并转换,输出结果写入新文件。截图:

优点:处理速度快。缺点:Excel数据量很多时效率低,使用文件时出现严重卡顿。

3、坐标转换工具CSV版Toolbox,主要功能利用CSV模块读写CSV(*.csv)记录坐标进行转换,主要思路:建立CSV文件模板,编写代码读取并转换,输出结果写入新文件,注意以二进制方式(‘wb’)进行读写,否则肯能会出现空白行问题(参考:python 2 csv写入空白行问题_zzzjojo123的博客-CSDN博客)。截图:

优点:CSV支持百万级数据读写操作,且处理速度快。

(二)脱离ArcGIS环境的exe程序

1、坐标转换工具矢量版exe程序

这个部分考虑到ArcGIS运行环境问题,利用基于Python的OSGeo、GeoPandas、Shapely等开源模块,通过算法设计实现与上文矢量版相同功能,从要素几何构成方面设计多部件要素与孔洞、孤岛多边形处理算法,解决无法转换的问题。至该文章发出时,该算法脚本已经通过数据测试,界面如下图所示。我在对脚本打包为exe可执行文件时,使用的是py2exe包,打包期间各种问题频出,不过都完美解决,关于py2exe打包GeoPandas模块时的问题解决方案送上(py2exe打包Geopandas、Pandas、Fiona、Requests、Openpyxl并发布为exe程序问题解决方案(持续更新)_yhiki的博客-CSDN博客)。

优点:(1)支持多部件要素以及孔洞、孤岛多边形;(2)脱离ArcGIS运行环境,处理效率相较于ArcGIS工具箱高。

缺点:Python2.7开发,运行路径有中文可能会出错,建议在非中文路径下运行。

2、坐标转换工具Excel与CSV版集成exe程序

Excel与CSV文件均属表格类型文件,因此进行集成,通过设计类模块与函数进行调用,最后打包为exe可执行程序。界面如下:

(三)链接

坐标转换工具矢量版Toolbox、坐标转换工具Excel与CSV版Toolbox暂不提供了;

坐标转换工具矢量版exe(建议放在英文路径下,否则可能会 错

       百度云:百度 盘 请输入提取码,提取码:sxmf

       蓝奏云:https://wwe.lanzous.com/iH8WBhwm82b,密码:d62z

坐标转换工具Excel与CSV版exe

       Excel表格为2010及以上版本*.xlsx格式

       百度云:百度 盘 请输入提取码,提取码:qqqn

       蓝奏云:https://wwe.lanzous.com/io6L6hp468f,密码:8v8i

软件为个人开发无毒,杀毒软件可能会 毒,可将exe文件添加信任。

使用方法:压缩包解压后,在【dist】目录中找到启动程序,双击程序运行,按下图依次点击即可使用。

若链接失效、使用中出现问题或提出建议请联系开发者(QQ:602168676)。

2020.09.08  第5次修改。

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2019年1月10日
下一篇 2019年1月10日

相关推荐