基于kml线路生成路线规划文档

2024-03-21 17:20

本文主要是介绍基于kml线路生成路线规划文档,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

在野外工程采集中,一线工作人员为了记录所在方位与坐标,一般会对相关点做标记,最终导出成一个kml格式的文件,该文件记录了一系列工程点和路线,很多工程报告需要根据这些线路来对周边环境进行描述,如高压线路的铺设,野外测绘等,比较严谨的方案是结合最新的影像地图以及其它实测数据和规划数据,由相关人员进行撰写,最近在研究自动化的过程,手里的数据比较少,因此仅仅实现一个思路。

读取kml

目的是将kml读取成可以解析的坐标

# 递归提取LineString点坐标
def extract_point_coordinates(element):"""递归函数,用于提取LineString的坐标。"""points = []if element.tag.endswith('LineString'):coords_text = element.find('kml:coordinates', ns).textcoords_pairs = coords_text.strip().split(' ')points = [(float(lat), float(lon)) for lon, lat, _ in (coords_pair.split(',') for coords_pair in coords_pairs)]return points# 对于MultiGeometry或Placemark,递归搜索其中的LineStringfor child in element:points += extract_point_coordinates(child)return points

查找相关POI

一个测量点也可以被看作一个拐点,即线路走到这里会发生改变,因此需要找到附近的地物点及方向,以便加以描述

#寻找周边地物
def searcg_nearby_places(lon,lat,tk):"""通过经纬度和地物类型搜索周边地物"""base_url = 'http://api.tianditu.gov.cn/geocoder'params = {"postStr":json.dumps({'lon':lon,'lat':lat,'ver':1}),"type":"geocode","tk":tk}response = requests.get(base_url,params=params)if response.status_code == 200:return response.json()else:return None

通过poi能拿到对应点附近的地物信息,如经纬度,完整描述,所在城市、县区、最近点、最近点方位、到最近点距离等,但是还需要一个最终要的信息,就是路线的走线,及经过该点以后往哪个方向走。
走向可以用该点和下一个点的经纬度进行计算

#计算方向
def calculate_direction(point,next_point):"""计算两点之间的方向"""lat1,lon1 = pointlat2,lon2 = next_pointdLon = lon2 - lon1y = math.sin(dLon) * math.cos(lat2)x = math.cos(lat1) * math.sin(lat2) - math.sin(lat1) * math.cos(lat2) * math.cos(dLon)brng = math.atan2(y, x)brng = math.degrees(brng)brng = (brng + 360) % 360if brng > 337.5 or brng <= 22.5:return '正北'elif brng > 22.5 and brng <= 67.5:return '东北'elif brng > 67.5 and brng <= 112.5:return '正东'elif brng > 112.5 and brng <= 157.5:return '东南'elif brng > 157.5 and brng <= 202.5:return '正南'elif brng > 202.5 and brng <= 247.5:return '西南'elif brng > 247.5 and brng <= 292.5:return '正西'else:return '西北'

创建语句字典

需要对每个途径点创建语句描述:常见的语句描述有:

  • through_dict = [“途经”,“经过”,“行至”]
  • arrive_dict=[‘到达{}{}侧后,开始转向{}走线,’,‘到达{}{}区域,转向{}方向,继续走线,’]
  • (‘最终走出{}。\n线路进入{}后向{}走线’)
  • ‘{}{}{}侧,继续向{}方向走线,’
  • 对于每个途径点,先判断是否已经不在该市区,如果不在,则描述离开该地区,转向其他地区

根据poi信息依次读取每个途径点,生成相关的语句描述

for i in range(len(results)-1) :if i == 0:direction = results[i]['走向']str+= "向{}出线,".format(direction)pos = results[i]next_pos = results[i+1]county = pos['所在县区']next_county = next_pos['所在县区']current_city = countydescription = pos['描述']next_description = next_pos['描述']direction = pos['走向']next_direction = next_pos['走向']address_position = pos['相对于最近点方向']next_address_position = next_pos['相对于最近点方向']city = pos['所在城市']next_city = next_pos['所在城市']road = pos['最近道路']next_road = next_pos['最近道路']# road_direction = pos['相对于最近道路方向']# next_road_direction = next_pos['相对于最近道路方向']detail_desp = handler.extract_between(county,address_position,description)#考虑线路是否离开本地区if county != next_county:str+=('最终走出{}。\n线路进入{}后向{}走线。'.format(city+county,next_city+next_county,next_direction))#如果地区一样,则考虑道路# elif road == next_road and road_direction != next_road_direction:#     str+=('向{}跨越{}后向{}走线,'.format(direction,road,next_direction))   #最后考虑途径点elif current_city == county:if direction == next_direction:str+=('{}{}{}侧,继续向{}方向走线,'.format(through_dict[i%3],detail_desp,address_position,direction))else:str+=(arrive_dict[i%2].format(detail_desp,address_position,direction))elif current_city != county:str+=('{}{}{}侧,向{}方向走线,'.format(through_dict[i%3],detail_desp,address_position,direction))
str+= "最终接入******构架。"

生成word文档

#创建文档对象
doc = Document()
paragraphs = str.split('\n')for para in paragraphs:paragraph = doc.add_paragraph()paragraph.paragraph_format.alignment = WD_PARAGRAPH_ALIGNMENT.JUSTIFY  # 设置两端对齐paragraph.paragraph_format.first_line_indent = Pt(24)  # 设置首行缩进paragraph.paragraph_format.line_spacing_rule = WD_LINE_SPACING.SINGLE  # 设置单倍行距run = paragraph.add_run(' ' + para)run.font.size = Pt(12)  # 设置字体大小为小四run.font.name = '宋体'  # 设置字体为宋体
doc.save('result.docx')

最终生成了一篇三千多字文档,内容部分如下:

    线路进入惠州市惠东县后向正东走线。到达多祝镇林氏祠堂东南区域,转向正东方向,继续走线,到达多祝镇大坪西北侧后,开始转向东南走线,到达多祝镇上横坑塘东南区域,转向正南方向,继续走线,到达多祝镇9棵松西北侧后,开始转向正北走线,到达多祝镇9棵松西北区域,转向正东方向,继续走线,行至多祝镇竹盐岗西北侧,继续向东南方向走线,到达多祝镇谷离山西南区域,转向东南方向,继续走线,经过多祝镇合掌山东南侧,继续向正东方向走线,最终走出惠州市惠东县。

这篇关于基于kml线路生成路线规划文档的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Python实现word文档内容智能提取以及合成

《Python实现word文档内容智能提取以及合成》这篇文章主要为大家详细介绍了如何使用Python实现从10个左右的docx文档中抽取内容,再调整语言风格后生成新的文档,感兴趣的小伙伴可以了解一下... 目录核心思路技术路径实现步骤阶段一:准备工作阶段二:内容提取 (python 脚本)阶段三:语言风格调

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.