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

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

如下图所示:

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

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


一、要实现的功能

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

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

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

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

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

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

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

合并后的1个要素:

完美合并。


二、实现流程

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

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

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

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

主要代码如下:

cs 复制代码
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()方法如下:

cs 复制代码
// 获取输入文件夹下的所有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工具箱https://blog.csdn.net/xcc34452366/article/details/131506345

相关推荐
zybsjn43 分钟前
后端系统做国际化改造,生成多语言包
java·python·c#
敲代码的 蜡笔小新1 小时前
【行为型之迭代器模式】游戏开发实战——Unity高效集合遍历与场景管理的架构精髓
unity·设计模式·c#·迭代器模式
yc_12242 小时前
SqlHelper 实现类,支持多数据库,提供异步操作、自动重试、事务、存储过程、分页、缓存等功能。
数据库·c#
Kookoos3 小时前
Redis + ABP vNext 构建分布式高可用缓存架构
redis·分布式·缓存·架构·c#·.net
Zhen (Evan) Wang5 小时前
ABP-Book Store Application中文讲解 - Part 2: The Book List Page
c#
小乖兽技术6 小时前
在 .NET 8 开发的WinForms 程序中展示程序版本号的几种方式
开发语言·c#·.net
TheWindofFate6 小时前
C# 基础 try-catch代码块
c#·try-catch
玩大数据的龙威7 小时前
【ArcGIS技巧】根据地块、界址点图层生成界址线
arcgis
TIF星空10 小时前
【使用 C# 获取 USB 设备信息及进行通信】
开发语言·经验分享·笔记·学习·microsoft·c#
csdn_aspnet12 小时前
如何在 C# 中自定义 Datagridview 标题
c#·winform·datagridview