【ArcGIS Pro二次开发】(29):村庄规划生成空间功能结构调整表

本文主要是介绍【ArcGIS Pro二次开发】(29):村庄规划生成空间功能结构调整表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

根据现在村规成果要求,【空间功能结构调整表】是必需的。

以福建省为例,它长这样:

下面就来实现从现状用地和规划用地导出这样的Excel表格。


一、要实现的功能

如上图所示,点击【汇总村庄空间功能结构调整表】工具,选择【现状用地】和【规划用地】图层,选择要保存输出的Excel文件路径,再点击【执行】即可。

生成结果如下:

PS:注意输入的【现状用地】和【规划用地】的规范要求

一、【现状用地】

输入的【现状用地】图斑需要注意要有2个字段:【JQDLBM】和【CZCSXM】。

【JQDLBM】是村规入库的标准代码,即基期地类编码。

【CZCSXM】是三调自带的字段,用来表示三调用地的城镇村属性。201、201A是城市建设用地,202、202A是建制镇建设用地,203、203A是村庄建设用地。这里提取【201、201A、202、202A】作为城镇用地。

二、【规划用地】

输入的【规划用地】图斑需要注意要有2个字段:【GHDLBM】和【SSBJLX】。

【GHDLBM】和【SSBJLX】都是村规入库的标准代码。

【GHDLBM】即规划地类编码。

【SSBJLX】用来表示规划用地的城镇村属性,字段值为【Z】则表示该地块为城镇用地。这里为了照顾输入时的误差,字段值为小写的【z】也可以被认得。


二、实现流程

工具的实现流程和我的上一篇文章很像:

【ArcGIS Pro二次开发】(28):用地图斑导出用地用海汇总表

流程长但不复杂,更重要的是Excel模板和输入【现状用地、规划用地】的准备。

1、准备Excel模板

一、【空间功能结构调整表】模板

首先是要输出表的模板,需要输入的单元格包括面积、比重、和面积增减。这里的大部分面积值由用地汇总而来,部分合计值、比重以及面积增减值就在Excel里用公式计算。另外,还需要一个参照列,用来属性映射。

二、【用地用海代码_村庄功能】属性映射表

这个表格是作为用地用海代码向村庄功能映射的参照表,将用地用海代码转换成村庄功能代码。

2、主要代码

实现功能的主要流程如下:

            // 获取默认数据库string init_gdb = Project.Current.DefaultGeodatabasePath;// 获取默认文件夹位置string init_path = Project.Current.HomeFolderPath;// 获取参数string yd_xz = combox_fc_xz.Text;           // 现状用地string yd_gh = combox_fc_gh.Text;         // 规划用地string excel_GN = init_path + @"\用地用海代码_村庄功能.xlsx";    // 村庄功能映射Excelstring excel_TZB = textExcelPath.Text;      // 输出空间功能结构调整表Excelstring output_table_xz = init_gdb + @"\output_table_xz";string output_table_gh = init_gdb + @"\output_table_gh";string statistics_fields = "Shape_Area SUM";string field_xz = "JQDLBM";string field_gh = "GHDLBM";string field_GN = "村庄功能";// 复制模板Excel和输出结果ExcelToolManager.CopyResourceFile(@"CCTool.Excel.用地用海代码_村庄功能.xlsx", excel_GN);ToolManager.CopyResourceFile(@"CCTool.Excel.【模板】空间功能结构调整表.xlsx", excel_TZB);// 现状、规划用地功能映射GN_Mapper(yd_xz, field_xz, field_GN, excel_GN);GN_Mapper(yd_gh, field_gh, field_GN, excel_GN);// 统计面积ToolManager.MultiStatistics(yd_xz, output_table_xz, statistics_fields, new List<string>() { field_GN }, "总计", 1, true);ToolManager.MultiStatistics(yd_gh, output_table_gh, statistics_fields, new List<string>() { field_GN }, "总计", 1, true);// 删除中间字段Arcpy.DeleteField(yd_xz, field_GN);Arcpy.DeleteField(yd_gh, field_GN);// 属性映射至ExcelToolManager.ExcelAttributeMapper(excel_TZB + @"\sheet1$", 13, 6, "output_table_xz", @"分组字段", "SUM_Shape_Area", 5);ToolManager.ExcelAttributeMapper(excel_TZB + @"\sheet1$", 13, 8, "output_table_gh", @"分组字段", "SUM_Shape_Area", 5);// 删除0值行ToolManager.Delete0Row(excel_TZB + @"\sheet1$", new List<int>() {6, 8}, 5);// 删除参照列ToolManager.DeleteColumns(excel_TZB + @"\sheet1$", new List<int>() { 13 });// 删除中间数据Arcpy.Delect(new List<string>() { output_table_xz, output_table_gh });

其中【GN_Mapper】方法用于计算城村庄功能字段:

        // 村庄功能映射public async void GN_Mapper(string yd, string field_bm, string field_GN, string excel_GN){// 汇总统计现状用地Arcpy.AddField(yd, field_GN, "TEXT");     // 添加一个参照字段// 属性映射ToolManager.AttributeMapper(yd, field_bm, field_GN, excel_GN + @"\sheet1$");// 计算城镇用地var map = MapView.Active.Map;FeatureLayer init_layer = map.FindLayers(yd)[0] as FeatureLayer;await QueuedTask.Run(() =>{using (ArcGIS.Core.Data.Table table = init_layer.GetTable()){using (RowCursor rowCursor = table.Search(null, false)){TableDefinition tableDefinition = table.GetDefinition();while (rowCursor.MoveNext()){using (Row row = rowCursor.Current){if (field_bm == "JQDLBM"){// 获取valuevar va = row["CZCSXM"].ToString();// 赋值if (va == "202" || va == "202A" || va == "201" || va == "201A"){row[field_GN] = "城镇用地";}}else if (field_bm == "GHDLBM"){// 获取valuevar va = row["SSBJLX"].ToString();// 赋值if (va == "Z" || va == "z"){row[field_GN] = "城镇用地";}}row.Store();}}}}});}

流程里涉及到的其它功能包括:复制Excel、属性映射、统计面积、Excel属性映射、删除0值行等,可以在以往的文章里查到,具体可以看上一篇文章,或在文章末尾提供的工程文件里查看。实在也没什么好讲的。

PS:这次提供的工程文件和别的工具合在一起了。代码里的功能嵌套越来越多,分离开来反而很麻烦,就将整个工具包一块分享了。


三、工程文件分享

最后,放上工程文件的链接:

StatisticVillagehttps://pan.baidu.com/s/1nsjUHqRqfogHrjis5pXDXw?pwd=dwsv

PS:可以直接点击...bin\Debug\net6.0-windows\下的.esriAddinX文件直接安装。

这篇关于【ArcGIS Pro二次开发】(29):村庄规划生成空间功能结构调整表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

动态规划---打家劫舍

题目: 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。 思路: 动态规划五部曲: 1.确定dp数组及含义 dp数组是一维数组,dp[i]代表

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言