1.问题描述
工程设计中,经常需要提取奥维地图或者谷歌地图中标记图形的边界点经纬度,如果图形较多,手动提取非常繁琐,因此自动提取这些信息就非常有必要。
2.解决思路
奥维地图和谷歌地图的转化文件是kml文件,上图是用记事本打开某kml文件后的内容。我们需要提取的信息是标记地方名称和对应的经纬度,观察发现,标记地方名称均在标签<name></name>内部,经纬度都在<coordinates></coordinates>内部,但需要注意的是并不是所有的<name></name>里都是标记地方名称,如图中位置1不是标记名称,位置2和3才是,而位置2,3与位置1不同的地方在于,位置2,3后面紧跟着<Style>标签,因此可以根据这个特点来找到所有标记地方名称。
根据所求信息的位置特点,用正则表达式来提取标记地方名和经纬度,然后将这些数据形成pandas的DataFrame对象,然后用该对象的to_csv方法输出csv格式文本。
3.代码实现
https://github.com/JohnYang1210/DesignWorkTask/blob/master/kmlExtractor/kmlCoordExtractor.pygithub.com4.打包为exe可执行文件
打包后的可执行文件如上,使用也非常简单,故不作详细说明,第一,点击“打开Kml文件”按钮,选择需要提取的kml文件,然后点击“确定”,然后点击“提取坐标”,最后在kml文件所在的文件夹下生成各个标记图形经纬度信息的csv文件。
5.下载该软件
链接:https://pan.baidu.com/s/1CtuLmDIGykD8quXLwL2thQ
提取码:4xc7
欢迎下载使用~