ArcMap属性字段自增引出字段计算器使用python的技巧
1 前言
前些日期有人问我ArcMap中要让某个字段的值实现自增有什么方法?我首先想到到像SQLServer中对于数值型字段可以设置自增。所以我打开ArcCatalog查看我发现只提供默认值,没办法只能看一下字段计算器中是否有更好的办法。开始我的方法是在字段计算器中将要自增的值等于默认的OBJECTID值,但是问题又来了,如果删除一个对象后,OBJECTID值变乱,又不能实现自增。但是它提供了支持VB脚本和Python脚本,于是参照帮助文档找到python脚本实现自增的方法,分享给大家。
2 帮助文档解析
打开计算字段实例文档找到(累加计算和顺序计算)
首先分析帮助文档提供的代码,注意红色部分为注释
Parser: Python #程序语言 Expression: autoIncrement() #表达式方法 Code Block: #下面这部分是具体实现,注意在放字段计算器时只需要下面这部分 rec=0 def autoIncrement(): #定义方法名 global rec pStart = 1 #初始值, 可以调整 pInterval = 1 #自增间隔, 可以调整 if (rec == 0): rec = pStart else: rec = rec + pInterval return rec
Parser:
Python #程序语言
Expression:
autoIncrement() #表达式方法
Code Block: #下面这部分是具体实现,注意在放字段计算器时只需要下面这部分
rec=0
def autoIncrement(): #定义方法名
global rec
pStart = 1 #初始值, 可以调整
pInterval = 1 #自增间隔, 可以调整
if (rec == 0):
rec = pStart
else:
rec = rec + pInterval
return rec
下面是如何在字段计算器中使用,目的实现ghg的字段自增
打开字段计算器进行设置如下:
注意:python将强制要求缩进作为语法的一部分,请使用四个空格来定义每个逻辑级别,将语句块的开头和结尾对其并保持一致。
查看结果实现自增
3 提升
其实使用python十分方便,如果没有python要实现自增对于一个大项目来说是很耗人力的。说道这里上面的那种方法中自定义函数没有输入参数,如果我们要输入参数该怎么写呢,查看帮助文档中有一个计算数值型字段的累加值的例子我们分析下。
Parser:
Python
Expression:
accumulate(!FieldA!) #该函数需要输入字段做参数
Code Block: #下面这部分是具体实现,注意在放字段计算器时只需要下面这部分
total = 0
def accumulate(increment):
global total
if total:
total += increment
else:
total = increment
return total
目的实现OBJECTID累加值赋值给ghg的字段
注意:Python 计算表达式字段将使用惊叹号 (!!) 括起。
结果:
4 python该怎么用
对于有编程基础的人来说,入门简单的python语法很容易,他和Java,C#等基础语言语法很像,例如控制流,if语句,while循环语句,for循环语句,break语句,continue语句等,几乎主流语言都有。
在ArcMap中也可以使用其他python库,例如random函数,可以实现随机值。
例如:通过numpy站点包来计算0.0和1.0之间的随机浮点值。
Parser:
Python
Expression:
getRandomValue()
Code Block:
import numpy.random as R
def getRandomValue():
return R.random()
5 总结
语言是一种工具,你只要精通一门语言,对于编程你会多一份自信。不管使用什么语言你都可以解决问题。使用编程的思想会大大的提高你的工作效率,所以朋友们你至少要学会一门语言,为了更好地工作。