Arcpy自动批量化制图:修改图层数据源 修改布局元素 导出布局地图

先上代码

# coding:utf-8_
import arcpy
import os

if __name__ == "__main__":
    tifdir = r'I:\DInSAR\PJQZ\result'
    shpdir = r'I:\DInSAR\reference'
    tifs = []
    with open("./filter_list.txt", mode='r') as f:
        tifs = f.readlines()
    tifs = [tif.strip() for tif in tifs]
    mxd = arcpy.mapping.MapDocument("template.mxd")
    player = arcpy.mapping.ListLayers(mxd, wildcard='Reference Point')[0]
    rlayer = arcpy.mapping.ListLayers(mxd, wildcard='DInSAR deformation value')[0]
    datetxt = arcpy.mapping.ListLayoutElements(mxd, element_type="TEXT_ELEMENT", wildcard='TITLE')[0]
    hightxt = arcpy.mapping.ListLayoutElements(mxd, element_type="TEXT_ELEMENT", wildcard='HIGH')[0]
    lowtxt = arcpy.mapping.ListLayoutElements(mxd, element_type="TEXT_ELEMENT", wildcard='LOW')[0]
    for tif in tifs:
        tifpath = os.path.join(tifdir, tif)
        raster = arcpy.Raster(tifpath)
        maxvalue = raster.maximum
        minvalue = raster.minimum
        maxvalue = format(maxvalue * 100, "0.1f")
        minvalue = format(minvalue * 100, "0.1f")
        arcpy.mapping.Layer.replaceDataSource(player, shpdir, workspace_type='SHAPEFILE_WORKSPACE',
                                              dataset_name='{}.shp'.format(tif[0:-4]), validate=True
                                              )
        arcpy.mapping.Layer.replaceDataSource(rlayer, tifdir, workspace_type='RASTER_WORKSPACE',
                                              dataset_name=tif, validate=True)
        datetxt.text = tif[0:-4]
        hightxt.text = 'High : {} cm'.format(maxvalue)
        lowtxt.text = 'Low : {} cm'.format(minvalue)
        arcpy.mapping.ExportToPNG(mxd, "./png/{}.png".format(tif[0:-4]), "PAGE_LAYOUT", resolution=384)
        arcpy.mapping.MapDocument.saveACopy(mxd, "./mxd/{}.mxd".format(tif[0:-4]))
        print "{} ok!".format(tif)

结果输出

在这里插入图片描述

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用ArcPy中的数据集合工具(Data Management Tools)中的相关工具来实现此功能。以下是一个示例代码: ``` import arcpy # 设置工作空间和数据集 arcpy.env.workspace = r"C:\data" gdb = "my_geodatabase.gdb" dataset1 = "my_dataset1" dataset2 = "my_dataset2" dataset3 = "my_dataset3" # 获取数据集的路径 path1 = arcpy.Describe(gdb + "\\" + dataset1).catalogPath path2 = arcpy.Describe(gdb + "\\" + dataset2).catalogPath path3 = arcpy.Describe(gdb + "\\" + dataset3).catalogPath # 使用CopyFeatures工具复制数据集1到数据集2和数据集3 arcpy.CopyFeatures_management(path1, path2) arcpy.CopyFeatures_management(path1, path3) # 使用CalculateField工具在数据集2和数据集3中更新字段值 expression = "my_expression" field = "my_field" arcpy.CalculateField_management(path2, field, expression) arcpy.CalculateField_management(path3, field, expression) ``` 在上述代码中,我们首先指定工作空间和数据集名称,然后使用`arcpy.Describe()`方法获取每个数据集的路径。接下来,我们使用`arcpy.CopyFeatures_management()`方法将数据集1复制到数据集2和数据集3中。最后,我们使用`arcpy.CalculateField_management()`方法更新数据集2和数据集3中的字段值。 请注意,这个示例代码仅供参考,并且您需要根据自己的数据和需求进行修改。同时,建议您在使用数据集合工具(Data Management Tools)时先备份数据以避免意外修改

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值