由ArcMap属性字段自增引出字段计算器使用Python的技巧

1.前言

      前些日子有人问我ArcMap中要让某个字段的值实现自增有什么方法?我首先想到像SQL Server中对于数值型字段可以设置自增。所以我打开ArcCatalog查看发现只提供默认值,没办法只能看一下字段计算器中是否有更好的方法。开始我的方法是在字段计算器中将要自增的值等于默认的OBJECTID值,但是问题又来啦,如果删除一个对象后OBJECTID值变乱,又不能实现自增。本人学习的主要语言是c#,对于字段计算器所支持的VB脚本和Python不了解,对于c#来说写一个for循环很容易实现自增。最后参照帮助文档找到了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
下面是如何在字段计算器中使用

目的实现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 语句 2. while语句 3. for 循环 for..in  4. break语句 5. 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.总结

语言是一种工具,你只要你精通一门语言,对于编程你会多一份自信。不管使用什么语言你都可以解决问题。使用编程的思想会大大的提高你的工作效率,所以朋友们你至少要学会一门语言,为了更好地工作。

 

参考资料:ArcGIS10.2 帮助库

你可能感兴趣的:(由ArcMap属性字段自增引出字段计算器使用Python的技巧)