arcpy 解析土地整治报备坐标点为是矢量面

2023-10-06 03:01

本文主要是介绍arcpy 解析土地整治报备坐标点为是矢量面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据格式:

代码片段:

# coding: utf-8import os
import arcpy
import json
import sysdef set_encoding():a, b, c = sys.stdin, sys.stdout, sys.stderrreload(sys)sys.setdefaultencoding('utf-8')sys.stdin, sys.stdout, sys.stderr = a, b, cdef get_files(root):files = os.listdir(root)return filesdef create_feature(root, workspace, sp_ref):temp_dic_root, database = get_path(workspace)temp_dic = os.path.join(temp_dic_root, "temp_data")if not os.path.exists(temp_dic):os.makedirs(temp_dic)for sourcefile in get_files(root):if not sourcefile.endswith(".txt"):continuefilename = os.path.splitext(sourcefile)[0]out_file = workspace + "\\v_" + filenamejsonfile = os.path.join(temp_dic, filename + ".json")sourcefile = root + "\\" + sourcefilecoordinates = analysis(sourcefile)if create_geojson(jsonfile, coordinates, sp_ref):arcpy.JSONToFeatures_conversion(jsonfile, out_file)arcpy.AddMessage("info: " + filename)else:arcpy.AddWarning("waring: " + filename)def create_geojson(targetfile, coordinates, sp_ref):features_template = {"displayFieldName": "","fieldAliases": {"FID": "FID"},"geometryType": "esriGeometryPolygon","spatialReference": {"wkt": ""},"fields": [{"name": "FID","type": "esriFieldTypeOID","alias": "FID"}],"features": []}features_template["spatialReference"]["wkt"] = sp_reffor fid, item in enumerate(coordinates):features_template["features"].append(get_geometry(fid, item))with open(targetfile, "w") as out_file:out_file.write(json.dumps(features_template))return Truedef get_geometry(fid, rings):feature_template = {"attributes": {"FID": 0}, "geometry": {"rings": []}}feature_template["attributes"]["FID"] = fidtemp = [ring for index, ring in rings.items()]feature_template["geometry"]["rings"].extend(temp)return feature_templatedef analysis(sourcefile):geometry = []rings = {}with open(sourcefile, "r") as in_file:line = in_file.readline()while line:flag1 = "@" in line.replace("\n", "").split(",")flag2 = line.startswith("J")if not (flag1 or flag2):line = in_file.readline()continueif flag1:geometry.append(rings)rings = {}elif flag2:temp = line.split(",")ring_index = temp[1]ring_part = list(map(float, reversed(temp[2:])))if not rings.has_key(ring_index):rings[ring_index] = []rings[ring_index].append(ring_part)line = in_file.readline()geometry.append(rings)geometry.pop(0)return geometrydef get_path(path):temps = path.split('\\')result = []if '.' in temps[-1]:root = "\\".join(temps[0:-1])result.append(root)result.append(temps[-1])return resultif __name__ == "__main__":set_encoding()root = arcpy.GetParameterAsText(0)workspace = arcpy.GetParameterAsText(1)sp_ref = arcpy.GetParameterAsText(2)sp_ref = sp_ref.replace("\'", "\"")create_feature(root, workspace, sp_ref)

 工具参数:

工具界面:

这篇关于arcpy 解析土地整治报备坐标点为是矢量面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

Python绘制土地利用和土地覆盖类型图示例详解

《Python绘制土地利用和土地覆盖类型图示例详解》本文介绍了如何使用Python绘制土地利用和土地覆盖类型图,并提供了详细的代码示例,通过安装所需的库,准备地理数据,使用geopandas和matp... 目录一、所需库的安装二、数据准备三、绘制土地利用和土地覆盖类型图四、代码解释五、其他可视化形式1.

Java解析JSON的六种方案

《Java解析JSON的六种方案》这篇文章介绍了6种JSON解析方案,包括Jackson、Gson、FastJSON、JsonPath、、手动解析,分别阐述了它们的功能特点、代码示例、高级功能、优缺点... 目录前言1. 使用 Jackson:业界标配功能特点代码示例高级功能优缺点2. 使用 Gson:轻量

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库