在ArcGIS中使用ArcPython批量合并多个文件型地理数据库(*.gdb)或个人地理数据库(*.mdb)
最近在做农村地籍建库和汇交工作,其中需要把某个县市100多个村子的农村地籍数据库合并在一起,最终作为这个县市的最终数据整理汇交,代码如下:
import sys
import arcpy
import string
try:
workspace = 'C:\Users\Administrator\Desktop\春化'
outdb = 'C:\Users\Administrator\Desktop\\县级数据库.mdb'
arcpy.env.workspace=outdb
fs = arcpy.ListFeatureClasses()
arcpy.env.workspace=workspace
for File in arcpy.ListFiles("*.*db"):
for f in fs:
arcpy.Append_management(File+"\\"+f, outdb+"\\"+f)
except arcpy.ExecuteError:
print arcpy.GetMessages()
实际动手操作如下:
1.准备数据
注意:outdb也就是目标数据库不要放到要被批量合并的数据库的文件夹下
2.打开ArcGIS的Python窗口,复制上述代码(注意要把路径改成你自己的),回车开始执行。
已经测试过有效,ArcGIS10.2及以上版本更稳定。
2018-6-27更新:增加了新功能,可以合并数据集(DataSet)中的数据,也就是说,在数据库格式一致的情况下,可以合并点、线、面、注记、属性表以及数据集中的点、线、面、注记、属性表,脚本如下:
import sys
reload(sys)
sys.setdefaultencoding("utf-8")
import arcpy
import string
try:
workspace = 'C:\Users\Administrator\Desktop\\cc'
outdb = 'C:\Users\Administrator\Desktop\\lutian.mdb'
arcpy.env.workspace = workspace
files = arcpy.ListFiles("*.*db")
arcpy.env.workspace = outdb
fcs = arcpy.ListFeatureClasses()
fcs = fcs + arcpy.ListTables()
dss = arcpy.ListDatasets()
for File in files:
for fc in fcs:
arcpy.Append_management(workspace + "\\" + File + "\\" + fc, outdb + "\\" + fc)
for ds in dss:
fcs1 = arcpy.ListFeatureClasses(feature_dataset = ds)
for fc1 in fcs1:
arcpy.Append_management(workspace + "\\" + File + "\\" + ds + "\\" + fc1, outdb + "\\" + ds + "\\" + fc1)
except arcpy.ExecuteError:
print arcpy.GetMessages()
总结:有很多人留言遇到各种问题,看不见你们的数据,看不到你们改后的代码,没有经过调试,判断不出是什么问题。我相信大部分人还是成功的,至少我每次都是成功的,我上文中提到数据库格式一致的情况下是肯定没有问题的。我估计出现问题的有以下原因:数据的问题,字段名相同,但字段类型不同导致字段类型强制转换出错;数据库格式都完全一致,但某个字段设置为不允许为空,当出现空值是出错。 解决办法我想是:首先看看自己的数据是否有以上情况,可以如下加几个参数(加粗字)arcpy.Append_management(workspace + "\\" + File + "\\" + fc, outdb + "\\" + fc ,"NO_TEST" , "" ,"") ,至于原因可以研究一下帮助文档,学习ArcGIS帮助文档是最好的老师。最后祝所有人顺利!
PS:根据以上代码,制作了python脚本工具,详细请看我另一篇文章。https://blog.csdn.net/Putin_leon/article/details/105514517