Arcpy脚本环境运行问题工作空间与环境

如何解决Arcpy脚本环境运行问题工作空间与环境

因此,我正在进行esri学院的Arcpy练习,但是在第一个练习中有些东西无法缠住我的头。 他们提供了空间参考脚本和地图布局脚本

空间参考脚本如下

#import modules
import arcpy

#set workspace
arcpy.env.workspace = r"C:\EsriTraining\PythEveryone\RunningScripts\Polk_County\OregonPolk.gdb"

#set up a describe object for each fc in geodatabase
fcList = arcpy.ListFeatureClasses()
for fc in fcList:
    desc = arcpy.Describe(fc)
    print (desc.spatialReference.name)
print (fcList)
print ("Script completed")

和地图布局脚本看起来像

#import modules
import arcpy

#set environment
aprx = arcpy.mp.ArcGISProject("CURRENT")

#specify layout
lyt = aprx.listLayouts("PolkGrdWater")[0]

#list layout text elements
eleList = lyt.listElements("TEXT_ELEMENT")

#loop through list and find all text elements with "Polk County" title
for ele in eleList:
    if ele.text == "Polk County":
        ele.text = "Polk County,OR"

#refresh the active view
aprx.save()
del aprx

print ("Script completed")

我了解到Map布局脚本更适合在ArcGISpro Python窗口中运行,但是我不明白的是为什么我无法以与运行Spatial相同的方式让Map布局脚本在Pycharm中运行参考脚本,我想如果我改变了

#set environment
aprx = arcpy.mp.ArcGISProject("CURRENT")

#set environment
aprx = arcpy.mp.ArcGISProject("Polk_County")

#set environment
aprx = arcpy.mp.ArcGISProject(r"C:\EsriTraining\PythEveryone\RunningScripts\Polk_County")

但是我想这与缺乏了解设置工作环境和设置工作空间之间的区别有关吗?

解决方法

您需要传入正确的输入参数。

通过传入 ArcGIS Pro项目的路径(一个.aprx文件)来实例化该对象。

如果您是在ArcGIS Pro中运行此程序并且已经打开了一个项目,则只需传入"CURRENT",随附的Python解释器就会理解为您的意思是“此Pro项目的文件路径”。但是,这在Pycharm或类似的IDE中不起作用,因为脚本没有针对您正在谈论的项目文件的引用:)

因此,当您想在独立脚本中创建ArcGISProject对象时,请提供特定项目文件的完整路径,而不仅仅是其所在目录的完整路径。例如>

aprx = arcpy.mp.ArcGISProject(r"C:\EsriTraining\PythEveryone\Polk_County\Polk.aprx")

查看Esri Help page about an ArcGISProject object,了解更多详细信息和参数。


但是,该问题与arcpy.env.workspace无关。根据您感兴趣的特定arcpy函数,可能需要也可能不需要设置environment workspace。但是,这些通常是与数据相关的工具,因此,您的工作区将是地理数据库(对于要素类)或目录(对于shapefile)。使用地理数据库中的空间数据时,工作空间至关重要。在Pro项目中使用地图布局时,工作空间无关。

在第一个示例脚本中,如果没有先设置arcpy.ListFeatureClasses参数,那么arcpy.env.workspace工具将无法使用。这是arcpy可能有点古怪的地方,因为其他工具(例如arcpy.CreateFeatureClass)希望将工作空间作为参数传递,而不是设置为外部参数。

需要实践和经验(和/或阅读帮助页面)才能知道工作区何时重要,何时不重要。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res