图斑整理之字段计算器使用技巧
- 字段计算器简介
在数据整理过程中经常要用到对属性表的处理,即为字段进行赋值或运算。字段计算器(Field Calculator)是一个强大的处理字段值的工具,不仅可以实现快速批量赋值,还支持Python和VBScript,可以通过代码进行复杂条件的赋值工作,并且字段计算器还可以在Model Builder中调用,构建空间模型。
在某个属性字段的右键菜单中即可调出字段计算器,在该界面中即可对该字段进行统一批量赋值,如果勾选Show Codeblock可以编写代码实现条件赋值、复杂计算或是几何体的计算。下面我们就以国土行业的图斑数据整理为例,看看灵活而强大字段计算器是如何应用的。
2. 应用实例
已有的图斑数据的属性表如下,两个字段分别代表二级地类的编码(DLBM)和名称(DLMC)。
- 截取拼接字符串
问题描述:从已有的DLBM(二级地类编码)中提取一级地类的编码,由于前两位即是一级地类编码,我们可以通过字符串的截取来实现
解决方法:创建字段YJDL,在字段计算器内选择Python,输入!DLBM![0:2]
注:Python中对字符串的处理非常简单,直接通过下标位置的索引来提取,拼接字符串则可使用加号来连接字段即可。
- 条件赋值
问题描述:根据一级地类的代码为其增加具体描述信息
解决方法:创建字段YJDLMC(一级地类名称),勾选Show Codeblock,根据YJDL的代码为其赋值,在YJDLMC=下面输入CalDLMC(!YJDL!),在上面的Pre-Logic Script Code空白处输入代码如下:
def CalDLMC(code):
if(code==’01’):
return “耕地”
elif(code==’02’):
return “园地”
else:
return “”
- 为重复记录进行编号
问题描述:将同一地类图斑自动编号(标记重复记录),例如根据DLBM字段,把具有相同值的记录标出来,并且按照从小到大的排序自动增加一个编号,实现如下效果:
解决方法:增加DLCOUNT字段,计算每种用地类型有多少块,即同类型的DLBM按顺序从1开始赋值,勾选Show Codeblock,编写代码:
UniqueDict = {}
def isDuplicateIndex(inValue):
UniqueDict.setdefault(inValue,0)
UniqueDict[inValue] += 1
return str(UniqueDict[inValue])
- 计算几何体信息
计算图斑面积:!Shape.Area!
质心X坐标:!Shape.CENTROID.X!
质心Y坐标:!Shape.CENTROID.Y!
- 字段间运算
在上一步计算得到的面积基础上进行单位转换,如将平方米转换为平方公里
!Area! /1000000
- 顺序赋值,即为每条记录进行唯一值编号
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?