欢迎访问 生活随笔!

生活随笔

当前位置: 首页 >

arcmap中添加python脚本_基于Python脚本的ArcMap字段计算器分类赋值

发布时间:2025/3/15 41 豆豆
生活随笔 收集整理的这篇文章主要介绍了 arcmap中添加python脚本_基于Python脚本的ArcMap字段计算器分类赋值 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

因为出差等等缘由,又没能很好的坚持记录博客,今天回来了,继续记录所学吧。python

ArcMap中提供了“字段计算器工具”,实际上就是对Sql语句进行了可视化封装,造成了一个具备计算器外观的Sql语句编辑器窗口。利用字段计算器工具,咱们能够直接在AacMap中针对图层的属性表进行数据的增删改查等操做,从而避免了操做图形的同时切换到Oracle、sqlserver、access等存储介质中操做属性表的麻烦。(之前批量处理数据时,采用的就是讲数据导进mdb中,而后利用Access打开写sql语句进行操做的方法,相比于字段计算器来讲,麻烦的多)sql

字段计算器工具很方便,可是编辑起来交互不友好,并且python语法对于缩进要求很严格,这个编辑器也没有智能缩进和代码提示的功能,彻底要求编辑者在相似纯记事本的状态下进行编辑,必定要十分谨慎认真才能执行出想要的结果。下面咱们用具体事例来说解操做过程。编辑器

以下图所示,函数

咱们有一个图层,是关于一些两栖类和爬行类动物的数据,咱们打开属性表,能够看到包含主键(OBJECTID),动物名称(NAME),科名称(FAMILY_NAME),目名称(ORDER_NAME),数量等级(NUMBER_CLASS),生境(ENVIRONMENT)等字段,其中生境这列字段的值是空的,须要填写,而这列值得内容和科名称这一列有相关性关系;通常来讲,同一科的动物,其生境相同,好比:“游蛇科”的生境都是“草树丛”,“石龙子科”的生境都是“石壁、草丛”;这样咱们就能够根据不一样的“科名称”来对“生境”这一字段进行分类赋值。工具

一、选择字段,打开字段计算器:sqlserver

首先打开图层的属性表,右击鼠标选中“生境(ENVIRONMENT)”字段,选择“字段计算器”选项并单击打开,以下图所示:测试

二、打开python代码块编辑器,编写赋值函数:spa

咱们须要勾选上图中的“显示代码块”前的勾选框,这时会显示出编写代码块的区域,咱们同时要在最上面选择Python脚本进行解析:咱们在代码块区域编写一个带返回值的函数,用来基于“科名称(FAMILY_NAME)”这一字段进行分类,这个函数索性就叫“填充(Fill)”吧,它具备一个形参f,咱们进行分类的条件是科名称的不一样,因此编写以下代码:server

def Fill(f):blog

if f == u"游蛇科":

return "草树丛"

elif f == u"石龙子科":

return "石壁、草丛"

而后在下面的填充值区域,也就是 ENVIRONMENT=  下面的文本框中调用这个函数,只需写出函数名Fill(),而后将光标移到括号中,在上面的字段列表中双击“FAMILY_NAME”这个字段就会显示出完整的函数,并传递实参,不全的内容以下:Fill( !NUMBER_CLASS! )  (注意:括号中选择的字段必定是基于分类的那个字段!)

完整的代码截图以下:

这时就获得了咱们的计算结果,以下图所示:

咱们还能够继续补充代码,一次性列举出所有分类条件,而后一次性执行进行所有分类赋值。

如何分类条件是空值,好比咱们要根据“科名称(FAMILY_NAME)”这一列中的 处的这些值统一对某列字段赋值,要如何编写代码呢?通过测试发现,凡是记录中为的这些地方,其值是None 而不是 Null, 因此赋值条件应该写成 if f == None:

注意:

一、python语法严格依赖缩进,在此代码边继快中,统一用英文状态两个字符缩进进行书写,不然报错。

二、当分类条件的字段中记录为中文的地方,须要在中文字符串前面加上U 来进行转码,不然会致使不能识别条件从而使要填充的字段计算结果永远是空值。

三、记录中为 的地方,若是想用这些地方的值做为分类条件,条件语句要写成 if f == None:

总结

以上是生活随笔为你收集整理的arcmap中添加python脚本_基于Python脚本的ArcMap字段计算器分类赋值的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。