【ArcGIS Pro二次开发】(54):三调名称转用地用海名称

三调地类和用地用海地类之间有点相似但并不一致。

在做规划时,拿到的三调,都需要将三调地类转换为用地用海地类,然后才能做后续的工作。

一般情况下,三调转用地用海存在【一对一,多对一和一对多】3种情况。

前2种情况直接转换,第3种情况一般转为【待细分】,后续详细调研。一些简单的目前也采用直转,如【交通服务场站用地】直转为【社会停车场用地】,这部分后续再详细推敲。


一、要实现的功能

如上图所示,点击【规划应用】组,【三调】面板下的【三调转用地用海】工具。

弹出工具框如下:

输入参数中:

1、选择三调用地图层。

2、选择三调的地类名称字段,正常情况下应该是【DLMC】。

3、选择要转换输出的字段(文本型)。

点击执行,结果如下:

根据一一映射关系,生成用地用海地类名称。


二、实现流程

这个工具其实就是用了属性映射的方法,准备好三调和用地用海之间的转换表即可。

可查看之前的文章:

【ArcGIS Pro二次开发】(25):属性映射

准备的映射表:

核心代码并不长,和属性映射工具类似。

直接贴上,不详细讲了。

cs 复制代码
                await QueuedTask.Run(() =>
                {
                    // 获取工程默认文件夹位置
                    var def_path = Project.Current.HomeFolderPath;
                    // 复制符号图层文件
                    ToolManager.CopyResourceFile(@"CCTool.Data.Excel.三调用地名称_to_用地用海用地名称.xlsx", def_path + @"\三调用地名称_to_用地用海用地名称.xlsx");
                    // 获取连接表的2个字段名
                    string map_table = def_path + @"\三调用地名称_to_用地用海用地名称.xlsx\sheet1$";
                    string exl_field01 = ToolManager.GetCellFromExcel(map_table, "A1");
                    string exl_field02 = ToolManager.GetCellFromExcel(map_table, "B1");
                    List<string> fields = new List<string>() { exl_field02 };
                    // 连接字段
                    Arcpy.JoinField(in_data, in_field, map_table, exl_field01, fields);
                    // 计算字段
                    Arcpy.CalculateField(in_data, map_field, "!" + exl_field02 + "!");
                    // 删除多余字段
                    Arcpy.DeleteField(in_data, fields);
                });

三、工具文件分享

我把工具都集合成工具箱,不再单独放单个工具,可以到这里下载完整工具箱,会不断更新:

【ArcGIS Pro二次开发】:CC工具箱https://blog.csdn.net/xcc34452366/article/details/131506345PS:可以直接点击...bin\Debug\net6.0-windows\下的.esriAddinX文件直接安装。

相关推荐
烛阴2 小时前
隐式vs显式:解密C#类型转换的底层逻辑
前端·c#
梦里不知身是客113 小时前
kafka作为Sink
c#·linq
猿来是你_L3 小时前
C# Dictionary 转换成 List
windows·c#·list
kokunka4 小时前
C#类修饰符功能与范围详解
java·开发语言·c#
mudtools4 小时前
.NET驾驭Excel之力:工作簿与工作表操作基础
c#·.net·excel
mudtools4 小时前
.NET驾驭Excel之力:单元格与区域操作详解
c#·.net·excel
用户8356290780517 小时前
C# 自动化生成 PowerPoint 演示文稿
后端·c#
饮品爱好者8 小时前
[C#] NO.4 我的第一个项目
vscode·职场和发展·c#·github
专注VB编程开发20年10 小时前
.net按地址动态调用VC++DLL将非托管DLL中的函数地址转换为.NET可调用的委托
开发语言·c++·c#·.net
玩泥巴的11 小时前
.NET驾驭Excel之力:工作簿与工作表操作基础
c#·excel·二次开发·office·com互操作