【ArcGIS Pro二次开发】(78):批量合并GDB数据库

有些GDB数据库会按分幅或行政区划进行分开储存,尤其是一些地形测绘或国情地理数据。

如下图所示:

数据是完整的,但使用的时候要一个一个拖进地图中,进行分析的时候也需要将其合并后使用。

因此就做了这个合库工具。


一、要实现的功能

 

如上图所示,在【数据处理】组—【GDB相关】面板下,点击【合并gdb数据库】工具。

在弹出的工具框中,分别输入参数:

1、输入要合并的GDB数据所在的文件夹。注意些文件夹下的所有gdb文件都会被读到,包括子文件夹下的。

2、输入合并后的GDB文件名,不需要输入【.gdb】。结果GDB文件会放在原文件夹下。

生成的GDB文件如下图所示:

生成GDB数据库的数据结构和原始GDB完全一致。

取一个要素查看一下,合并前的3个要素:

合并后的1个要素:

完美合并。 


二、实现流程

合并其实比较简单。可以将同名要素收集起来,然后调用GP合并工具即可。

或者用【追加】工具也可以同样实现。

主要的工作反而是在分析数据结构。

获取GDB数据库中的所有要素数据集和所有要素,根据其原来的数据路径,在目标GDB数据库中,同样创建要素数据集和要素类,并进行复制追加或合并复制。

主要代码如下:

await QueuedTask.Run(() =>
{
    // 获取所有GDB文件
    List<string> gdbFiles = gdbFolder.GetAllGDBFilePaths();

    // 创建合并GDB
    string gdbPath = Arcpy.CreateFileGDB(gdbFolder, gdbName);
    // 要素数据集列表
    List<string> dataBaseNames = new List<string>();
    // 要素类列表
    List<string> featureClassNames = new List<string>();

    foreach (string gdbFile in gdbFiles)
    {
        // 获取FeatureClass
        using (Geodatabase gdb = new Geodatabase(new FileGeodatabaseConnectionPath(new Uri(gdbFile))))
        {
            // 获取要素数据集
            IReadOnlyList<FeatureDatasetDefinition> featureDatases = gdb.GetDefinitions<FeatureDatasetDefinition>();
            // 新建要素数据集
            if (featureDatases.Count > 0)
            {
                foreach (var featureDatase in featureDatases)
                {
                    string dbName = featureDatase.GetName();
                    if (!dataBaseNames.Contains(dbName))   // 如果是新的,就创建
                    {
                        Arcpy.CreateFeatureDataset(gdbPath, dbName, featureDatase.GetSpatialReference());
                    }
                    dataBaseNames.Add(dbName);
                }
            }

            // 获取要素类
            IReadOnlyList<FeatureClassDefinition> featureClasses = gdb.GetDefinitions<FeatureClassDefinition>();
            if (featureClasses.Count > 0)
            {
                foreach (var featureClass in featureClasses)
                {
                    string fcName = featureClass.GetName();
                    FeatureClass fc = gdb.OpenDataset<FeatureClass>(fcName);
                    // 获取要素类路径
                    string fcPath = fc.GetPath().ToString().Replace("file:///", "").Replace("/", @"\");
                    // 获取目标路径
                    string targetPath = gdbPath + fcPath[(fcPath.IndexOf(".gdb") + 4)..];

                    if (!featureClassNames.Contains(fcName))   // 如果是新的,就复制要素类
                    {
                        Arcpy.CopyFeatures(fcPath, targetPath);
                        featureClassNames.Add(fcName);
                    }
                    else   // 如果已经有要素了,就追加
                    {
                        Arcpy.Append(fcPath, targetPath);
                    }
                }
            }
        }
    }
});

 其中获取所有GDB数据库文件的GetAllGDBFilePaths()方法如下:

// 获取输入文件夹下的所有GDB文件
public static List<string> GetAllGDBFilePaths(this string folderPath)
{
    List<string> gdbFilePaths = new List<string>();
    DirectoryInfo directoryInfo = new DirectoryInfo(folderPath);

    // 检查文件夹是否存在
    if (!directoryInfo.Exists)
    {
        throw new DirectoryNotFoundException("指定的文件夹路径不存在!");
    }

    // 查找所有GDB数据库文件(.gdb文件夹)
    DirectoryInfo[] gdbDirectories = directoryInfo.GetDirectories("*.gdb", SearchOption.AllDirectories);
    foreach (DirectoryInfo gdbDirectory in gdbDirectories)
    {
        // 获取GDB数据库的路径
        string gdbPath = gdbDirectory.FullName.Replace(@"/", @"\");

        // 添加到列表中
        gdbFilePaths.Add(gdbPath);
    }

    return gdbFilePaths;
}

三、工具文件分享

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

【ArcGIS Pro二次开发】:CC工具箱icon-default.png?t=N7T8https://blog.csdn.net/xcc34452366/article/details/131506345

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/204635.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

直播前期准备

直播前的准备是一个综合性的过程&#xff0c;需要从多个方面进行考虑和准备。以下是一些直播前准备的参考∶ 1.确定直播主题和目标∶明确直播的主题和目标&#xff0c;以及如何吸引观众。考虑观众的兴趣和需求&#xff0c;选择一个熟悉且具有吸引力的主题&#xff0c;以提升直…

字符串相似度匹配算法_莱茵斯坦距离算法

package day0330;public class LevenshteinDistanceUtil {public static void main(String[] args) {String a "WN64 F98";String b "WN64 F98 ";System.out.println("相似度:" getSimilarityRatio(a, b));}/*** 获取两字符串的相似度* * par…

扫码听音乐该如何制作?音乐的二维码生成方法

多个音频文件怎么做成一个二维码显示&#xff1f;二维码在现在的生活中拥有丰富的使用场景&#xff0c;可以用来作为多种内容类型的载体&#xff0c;比如音频二维码就是经常被使用的一种二维码类型。通过扫秒二维码来听音频文件&#xff0c;更加的灵活方便&#xff0c;那么音频…

六、shell编程

详见 《shell编程超详细入门教程》

队列基础(循环队列)

1.队列的定义: 和栈相反,队列(queue)是一种先进先出(first in first out,缩写为FIFO)的线性表.它只允许在表的一端进行插入,而在另一端删除元素. 在队列中,允许插入的一端叫做队尾(rear),允许删除的一端则称为队头(front). 2.循环队列的设计图示: 3.循环队列的结构设计: ty…

电话销售如何提高成功率

电话销售是一种非常有效的销售方式&#xff0c;睡着通信技术&#xff0c;互联网的发展&#xff0c;现在电话销售已经成为一种重要的销售方式&#xff0c;很多行业和领域都有使用。 虽然最终目的都是为了将产品卖出去&#xff0c;但是对于电话销售来说&#xff0c;前期寻找客户…

MySQL进阶知识:锁

目录 前言 全局锁 表级锁 表锁 元数据锁&#xff08;MDL&#xff09; 意向锁 行级锁 行锁 行锁演示 间隙锁/临界锁 演示 前言 MySQL中的锁&#xff0c;按照锁的粒度分&#xff0c;分为以下三类 全局锁&#xff1a;锁定数据库中的所有表。表级锁&#xff1a;每次操…

11-@Transaction与AOP冲突解决

如题&#xff0c;最近碰到了一个问题&#xff0c;在public方法上添加Transaction没有生效&#xff0c;事务没有回滚。 我自己模拟了一个功能&#xff0c;向数据库表User里面插入用户数据。说一下代码背景&#xff0c; 数据库MySQL&#xff0c;持久化层Mybatis&#xff0c;项目使…

Linux系统编程 day07 信号

Linux系统编程 day07 信号 1. 信号的介绍以及信号的机制2. 信号相关函数2.1 signal2.2 kill2.3 abort和raise2.4 alarm2.5 setitimer 3. 信号集4. 信号捕捉函数6. SIGCHLD信号7. SIGUSR1与SIGUSR2 1. 信号的介绍以及信号的机制 信号是信息的载体&#xff0c;在Linux/Unix环境下…

行业追踪,2023-11-30

自动复盘 2023-11-30 凡所有相&#xff0c;皆是虚妄。若见诸相非相&#xff0c;即见如来。 k 线图是最好的老师&#xff0c;每天持续发布板块的rps排名&#xff0c;追踪板块&#xff0c;板块来开仓&#xff0c;板块去清仓&#xff0c;丢弃自以为是的想法&#xff0c;板块去留让…

企业数字化转型应对传统网络挑战的关键策略

数字化变革正在以前所未有的速度和规模改变着我们的生活和工作方式&#xff0c;使得传统网络架构面临着巨大的挑战。其中包括带宽需求增加、多云应用增加、安全威胁增加以及传统网络设备无法满足需求等问题。 数字化时代需要更高速、更可靠、更安全的网络支持&#xff0c;传统网…

C语言必备知识--函数返回局部变量

0.总结 1. 不能以局部变量的方式创建字符串数组的首地址 2.如果函数的返回值非要是一个局部变量的地址&#xff0c;那么该局部变量一定要申明为static类型 3.返回指向字符串常量的指针 4.数组不能作为函数返回值 5.在函数中可以返回局部变量的值&#xff0c;但是不能返回…

如何安装鸿蒙Harmony 4.0低版API9三方库

比如我要用下拉刷新三方库pulltorefresh 安装命令如下 ohpm install ohos/pulltorefresh 安装完后然后运行Demo报错,说没有isAtEnd方法 然后查看pulltorefresh 最新版2.0.4对应Harmony API10,然而我的手机是API9,所以必须找到API9的库&#xff0c;然后查看2.0.1是还是API9 所…

docker集群的详解以及超详细搭建

文章目录 一、问题引入1. 多容器位于同一主机2. 多容器位于不同主机 二、介绍三、特性四、概念1. 节点nodes2. 服务(service)和任务(task)3. 负载均衡 五、docker网络1. overlay网络 六、docker集群搭建1. 环境介绍2. 创建集群3. 集群网络4. 加入工作节点 七、部署可视化界面po…

建设中国版MBA在线教育网站,群硕为Quantic敲开中国大门

2024考研即将拉开序幕&#xff0c;一个令人胆寒的问题出现在问答社区热榜—— 从现实来看&#xff0c;学历贬值已经成为一种全球现象。在卷学历的也不仅是大学生&#xff0c;还有很多职场人士&#xff0c;渴望通过获得MBA学位成为精英人才、商业领袖。 Quantic是交互式MBA线上…

热部署怎么部署

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言操作流程&#xff1a;在这里插入图片描述 ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/a832d83c091742eda9d9325931a89df4.png) 这里的跟上面的…

【自动化测试】pytest 用例执行中print日志实时输出

author: jwensh date: 20231130 pycharm 中 pytest 用例执行中 print 日志 standout 实时命令行输出 使用场景 在进行 websocket 接口进行测试的时候&#xff0c;希望有一个 case 是一直执行并接受接口返回的数据 def on_message(ws, message):message json.loads(message)…

Liunx配置Tomcat自启动

Liunx配置Tomcat自启动 Tomcat安装配置Tomcat开机启动 Tomcat安装 下载tomcat软件安装包&#xff0c;上传软件包到Liunx服务器。 解压软件包到opt目录下 tar -xvf apache-tomcat-9.0.76.tar.gz -c /opt配置Tomcat开机启动 &#xff08;1&#xff09;修改Tomcat bin目录下的ca…

有”亿“点强,抖音的服务器带宽是如何应对亿人同时刷屏的?

在当今这个“网络横行”的时代&#xff0c;刷短视频已然成为许多人日常生活的一部分。 当我们在刷短视频的时候&#xff0c;尽管家里的网速并不慢&#xff0c;但短视频播放的卡顿却让人难以忍受&#xff0c;有时候真的让人想扔掉手机。 那么&#xff0c;为什么会出现这种情况…

Elk+Filebeat+Kafka实现日志收集

ElkFilebeatKafka实现日志收集(本机nginx) 部署Zookeeper 1.实验组件 #准备3台服务器做Zookeeper集群 20.0.0.10 20.0.0.20 20.0.0.30 2.安装前准备 #关闭防火墙 systemctl stop firewalld systemctl disable firewalld setenforce 0#安装JDK yum install -y java-1.8.0-o…