arcpy 脚本介绍

部署运行你感兴趣的模型镜像

python在arcgis中的入口

可能大家总是听到arcpy,那它到底是啥东西
其实arcpy就是python的一个库,里面有很多arcgis的函数,arcgis的大多功能都可以调用,就像其他python库一样,调就完事了。
然后在arcgis中,python有两个入口,其中一个在上面的工具栏,在这里面可以直接写python,本文对这个不做讨论。
在这里插入图片描述
然后一种就是在目录中的工具箱中,在这个位置,你可以自己创建,只要是工具箱就可以。
在这里插入图片描述

arcpy如何创建

在这里可以新建一个自己的工具箱,工具箱的地方可以点击添加脚本,这个脚本其实就是我们常说的arcpy脚本,在arcgis中的应用。
在这里插入图片描述
在这里插入图片描述
这个标签就是你的脚本名字,改好了在外面也可以重命名
在这里插入图片描述
这里面就是你的.py文件,你要提前写好py文件然后在这里引进来,当然这个文件还可以改的,建成之后,右键编辑还可以改你的代码,改源文件代码也可以,这里的脚本代码就会随着立刻更新。
在这里插入图片描述
这里面是填写你的显示在外面的值,是输入还是输出,输入输出的格式,定义的东西,表现在外面的话就是下面这张图。
在上面的图里面,最上面是让你填这一行一行的,左面是填名称,就是下图中的输入图层、重金属啥的,右边会让你选这个是什么东西,比如输入图层就是一个要素图层,重金属是一个字段,选中一个的话,下面就是这一行的配置,比如默认数据,是输入还是输出,是必选还是可选,可不可以从图层中直接取,比如一些字段其实是图层里面的字段,你就可以设成可以从图层里面取的。在这里插入图片描述
这张图的输入输出都是靠上面的那个定义出来的。
然后你就会发现,其实arcgis工具箱中的很多文件都是这种类型的,比如经常用的这些在这里插入图片描述
他们也是arcpy脚本,你甚至可以右键编辑查看他们的源码。
然后他们的api其实就在帮助里面在这里插入图片描述
写的方法就和平常写python完全一样,只不过在arcgis中你可以调用他们的库他们的函数,arcgis给你提供了一个显示的界面。完毕~

您可能感兴趣的与本文相关的镜像

Python3.10

Python3.10

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

### 关于 arcpy 脚本中的中文处理 在编写涉及中文字符的 `arcpy` 脚本时,确保正确编码和解码字符串至关重要。Python 2.x 默认使用 ASCII 编码,在处理非ASCII字符(如中文)时可能会遇到问题。为了使脚本能顺利处理包含中文字符的数据源名称、字段名或其他文本信息,建议采取以下措施: #### 设置默认编码为 UTF-8 通过设置 Python 的默认编码为 UTF-8 可以有效解决大部分由于编码不匹配引起的问题。 ```python import sys reload(sys) sys.setdefaultencoding('utf-8') ``` 这段代码应该放置在脚本开头位置[^1]。 #### 使用 Unicode 字符串字面量表示法 当定义含有特殊字符(包括但不限于汉字)的字符串变量时,可以采用前缀 'u' 来声明它们为Unicode类型。 ```python feature_class_name = u"中国城市" workspace_path = r"C:\path\to\your\data.gdb" ``` 这有助于防止潜在的编码错误发生,并使得程序能够更好地理解所操作的对象及其属性值。 #### 文件路径中包含中文的情况 对于那些可能带有中文目录结构的工作空间路径参数,应当注意转义反斜杠或改用原始字符串语法来指定路径;另外还需确认操作系统支持相应语言环境下的文件访问权限。 ```python input_gdb = ur"D:\项目资料\地理信息系统\example_data.gdb" output_folder = "D:/临时输出/结果/" ``` 以上做法不仅适用于 Windows 平台下开发的应用程序,同样适合跨平台部署的需求。 #### 数据库连接与查询语句内的中文字符 如果要构建 SQL 查询表达式或者其他形式的操作命令传递给 GIS 工具函数,则需特别留意其中涉及到的文字内容是否已被适当转换为目标数据库所能接受的形式。 ```python where_clause = """NAME LIKE N'%北京%'""" with arcpy.da.SearchCursor(feature_layer, ["SHAPE@", "*"], where_clause=where_clause) as cursor: for row in cursor: # Process each feature here... pass ``` 这里的关键在于利用SQL标准里的N-prefix机制告知服务器端待比较项属于宽字符集成员之一。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值