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

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

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

【ArcGIS Pro二次开发】(54):三调名称转用地用海名称_第1张图片

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


一、要实现的功能

【ArcGIS Pro二次开发】(54):三调名称转用地用海名称_第2张图片

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

弹出工具框如下:

【ArcGIS Pro二次开发】(54):三调名称转用地用海名称_第3张图片

输入参数中:

1、选择三调用地图层。
2、选择三调的地类名称字段,正常情况下应该是【DLMC】。
3、选择要转换输出的字段(文本型)。

点击执行,结果如下:

【ArcGIS Pro二次开发】(54):三调名称转用地用海名称_第4张图片

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


二、实现流程

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

可查看之前的文章:

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

准备的映射表:

【ArcGIS Pro二次开发】(54):三调名称转用地用海名称_第5张图片

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

直接贴上,不详细讲了。

                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 fields = new List() { 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文件直接安装。

你可能感兴趣的:(ArcGIS,ArcGIS,Pro,SDK,arcgis,二次开发,c#,arcgis,pro,sdk,三调转用地用海)