基于Python脚本的ArcMap字段计算器分类赋值
由于出差等等原因,又没能很好的坚持记录博客,今天回来了,继续记录所学吧。
ArcMap中提供了“字段计算器工具”,实际上就是对Sql语句进行了可视化封装,形成了一个具有计算器外观的Sql语句编辑器窗口。利用字段计算器工具,我们可以直接在AacMap中针对图层的属性表进行数据的增删改查等操作,从而避免了操作图形的同时切换到Oracle、sqlserver、access等存储介质中操作属性表的麻烦。(以前批量处理数据时,采用的就是讲数据导进mdb中,然后利用Access打开写sql语句进行操作的方法,相比于字段计算器来说,麻烦的多)
字段计算器工具很方便,但是编辑起来交互不友好,而且python语法对于缩进要求很严格,这个编辑器也没有智能缩进和代码提示的功能,完全要求编辑者在类似纯记事本的状态下进行编辑,一定要十分谨慎认真才能执行出想要的结果。下面我们用具体事例来讲解操作过程。
如下图所示,
我们有一个图层,是关于一些两栖类和爬行类动物的数据,我们打开属性表,可以看到包含主键(OBJECTID),动物名称(NAME),科名称(FAMILY_NAME),目名称(ORDER_NAME),数量等级(NUMBER_CLASS),生境(ENVIRONMENT)等字段,其中生境这列字段的值是空的,需要填写,而这列值得内容和科名称这一列有相关性关系;一般来说,同一科的动物,其生境相同,比如:“游蛇科”的生境都是“草树丛”,“石龙子科”的生境都是“石壁、草丛”;这样我们就可以根据不同的“科名称”来对“生境”这一字段进行分类赋值。
1、选择字段,打开字段计算器:
首先打开图层的属性表,右击鼠标选中“生境(ENVIRONMENT)”字段,选择“字段计算器”选项并单击打开,如下图所示:
2、打开python代码块编辑器,编写赋值函数:
我们需要勾选上图中的“显示代码块”前的勾选框,这时会显示出编写代码块的区域,我们同时要在最上面选择Python脚本进行解析:我们在代码块区域编写一个带返回值的函数,用来基于“科名称(FAMILY_NAME)”这一字段进行分类,这个函数索性就叫“填充(Fill)”吧,它具有一个形参f,我们进行分类的条件是科名称的不同,所以编写如下代码:
def Fill(f):
if f == u“游蛇科”:
return “草树丛”
elif f == u“石龙子科”:
return “石壁、草丛”
然后在下面的填充值区域,也就是 ENVIRONMENT= 下面的文本框中调用这个函数,只需写出函数名Fill(),然后将光标移到括号中,在上面的字段列表中双击“FAMILY_NAME”这个字段就会显示出完整的函数,并传递实参,不全的内容如下:Fill( !NUMBER_CLASS! ) (注意:括号中选择的字段一定是基于分类的那个字段!)
完整的代码截图如下:
这时就得到了我们的计算结果,如下图所示:
我们还可以继续补充代码,一次性列举出全部分类条件,然后一次性执行进行全部分类赋值。
如何分类条件是空值,比如我们要根据“科名称(FAMILY_NAME)”这一列中的 <空> 处的这些值统一对某列字段赋值,要如何编写代码呢?经过测试发现,凡是记录中为<空>的这些地方,其值是None 而不是 Null, 所以赋值条件应该写成
if f == None:
注意:
1、python语法严格依赖缩进,在此代码边继快中,统一用英文状态两个字符缩进进行书写,否则报错。
2、当分类条件的字段中记录为中文的地方,需要在中文字符串前面加上U 来进行转码,否则会导致不能识别条件从而使要填充的字段计算结果永远是空值。
3、记录中为 <空> 的地方,如果想用这些地方的值作为分类条件,条件语句要写成 if f == None:
转载自:https://blog.csdn.net/SuperGiser_Lee/article/details/77183927