以arcgispro的python脚本为例在arcgispro自带的python窗口下运行python脚本
需求:
将arcgispro的.aprx项目包中gdb的数据源路径更换为sde数据源路径。
示例数据:testaprx_jb51.rar
演示过程:
方式一:脚本中指定好相关参数设置
import arcpy
import json
import sys
import os
import argparse
import re
result = ""
jsontext = {'success': {}, 'msg': ''}
def checkSavedAprxDatasource(output_aprx_path, mapName, targetDb):
check_result = True
desc = arcpy.Describe(targetDb)
saved_aprx = arcpy.mp.ArcGISProject(output_aprx_path)
for saved_map in saved_aprx.listMaps():
if saved_map.name == mapName:
for lyr in saved_map.listLayers():
if lyr.isFeatureLayer:
# print(lyr.connectionProperties)
if lyr.connectionProperties['workspace_factory'].upper() == 'SDE'.upper(
) and lyr.connectionProperties['connection_info']['instance'] == desc.connectionProperties.instance:
pass
else:
check_result = False
return check_result
if __name__ == '__main__':
try:
# linux
# aprxPath = str(sys.argv[1])
# mapName = str(sys.argv[2])
# sourceDb = str(sys.argv[3])
# targetDb = str(sys.argv[4])
# output_aprx_path = str(sys.argv[5])
# local pc
aprxPath = r'D:\rvt\testaprx\testaprx.aprx'
mapName = 'Map'
sourceDb = r'D:\rvt\testaprx\Data.gdb'
targetDb = r'D:\rvt\testaprx\testsde.sde'
output_aprx_path = r'D:\rvt\testaprx\output\export5.aprx'
aprx = arcpy.mp.ArcGISProject(aprxPath)
for m in aprx.listMaps():
if m.name == mapName:
m.updateConnectionProperties(sourceDb, targetDb)
if os.path.exists(output_aprx_path):
os.remove(output_aprx_path)
aprx.saveACopy(output_aprx_path)
checkResult = checkSavedAprxDatasource(
output_aprx_path, mapName, targetDb)
if checkResult:
jsontext['success'] = True
result = json.dumps(jsontext)
sys.stdout.write(result)
else:
jsontext['success'] = False
jsontext['msg'] = 'Failed to replace data source'
result = json.dumps(jsontext)
sys.stdout.write(result)
except Exception as e:
jsontext['success'] = False
jsontext['msg'] = e.args
result = json.dumps(jsontext)
sys.stdout.write(result)
方式二:使用sys.argv[ ]的形式设置相关参数
(arcgispro-py3) D:\rvt\testaprx>python test.py D:\rvt\testaprx\testaprx.aprx Map D:\rvt\testaprx\Data.gdb D:\rvt\testaprx\testsde.sde D:\rvt\testaprx\output\export5.aprx
import arcpy
import json
import sys
import os
import argparse
import re
result = ""
jsontext = {'success': {}, 'msg': ''}
def checkSavedAprxDatasource(output_aprx_path, mapName, targetDb):
check_result = True
desc = arcpy.Describe(targetDb)
saved_aprx = arcpy.mp.ArcGISProject(output_aprx_path)
for saved_map in saved_aprx.listMaps():
if saved_map.name == mapName:
for lyr in saved_map.listLayers():
if lyr.isFeatureLayer:
# print(lyr.connectionProperties)
if lyr.connectionProperties['workspace_factory'].upper() == 'SDE'.upper(
) and lyr.connectionProperties['connection_info']['instance'] == desc.connectionProperties.instance:
pass
else:
check_result = False
return check_result
if __name__ == '__main__':
try:
# linux
aprxPath = str(sys.argv[1])
mapName = str(sys.argv[2])
sourceDb = str(sys.argv[3])
targetDb = str(sys.argv[4])
output_aprx_path = str(sys.argv[5])
print("aprx路径: "+aprxPath)
print("地图视图的名称: "+mapName)
print("当前的数据源路径: "+sourceDb)
print("目标数据源路径: "+targetDb)
print("aprx另存为路径: "+output_aprx_path)
# local pc
# aprxPath = r'D:\rvt\testaprx\testaprx.aprx'
# mapName = 'Map'
# sourceDb = r'D:\rvt\testaprx\Data.gdb'
# targetDb = r'D:\rvt\testaprx\testsde.sde'
# output_aprx_path = r'D:\rvt\testaprx\output\export5.aprx'
aprx = arcpy.mp.ArcGISProject(aprxPath)
for m in aprx.listMaps():
if m.name == mapName:
m.updateConnectionProperties(sourceDb, targetDb)
if os.path.exists(output_aprx_path):
os.remove(output_aprx_path)
aprx.saveACopy(output_aprx_path)
checkResult = checkSavedAprxDatasource(
output_aprx_path, mapName, targetDb)
if checkResult:
jsontext['success'] = True
result = json.dumps(jsontext)
sys.stdout.write(result)
else:
jsontext['success'] = False
jsontext['msg'] = 'Failed to replace data source'
result = json.dumps(jsontext)
sys.stdout.write(result)
except Exception as e:
jsontext['success'] = False
jsontext['msg'] = e.args
result = json.dumps(jsontext)
sys.stdout.write(result)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“详解python命令提示符窗口下如何运行python脚本”评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新动态
2025年10月28日
2025年10月28日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]

