ArcGIS中的空值问题

空值是数据的一种特殊状态,当某个字段没有被赋值或者在数据获取、处理过程中数据缺失时就会出现空值。


01、空值的表现形式

【空值】不同于数字型的【零值】或者字符串型的【空格】。

数字型的【零值】是一个确定的数值,表示数量上为0。

字符串型的【空格】虽然看起来字段内没有内容,但在ArcGIS中空格也是一种有意义的内容。

而【空值】是没有任何数据的表示,通常情况下显示为<null>或<空>。

TIPS:在选择工具中,通过SQL表达式,可以很明显的看到【为空】和【空格】的区别:


02、空值的产生

空值的产生途径很多。

例如,在添加字段时,就有一个选项可以选择**【字段支持空值】**,如果勾选,新建字段的初始字段值就是空值。

另外,还可以通过字段计算器,输入【None】表达式来计算出空值。

(python是【None】, VB和Arcade是【null】)

或者在使用【连接字段】等处理字段类的地理处理工具时,也会产生空值。

总之,空值是不可避免的。


03、空值可能引发的问题

空值在数据库中有它存在的必要性,但是也会给我们带来很多困扰,尤其是对新手小白来说。

首先,如果你要按条件选择时,往往容易把【空值】和【空格】混在一起。

其次,【空值】在字段计算器经常会引发很多错误,因为在python中,空值是不能参与数学计算的。

这里的【NoneType】就是空值。

在数据汇总时,空值则会被跳过不计入统计。(这个可以当作是0)

在标注的时候,【空值】同样会影响表达式,产生错误。

在符号系统中,【空值】会当单独表达为一类,所以影响倒不是很大。


04、空值的处理

鉴于【空值】的诸多隐患,我个人习惯于尽量避免空值的出现,特别是一些需要后续处理的字段。

如果是少量字段值,可以直接编辑。

双击字段行,随便按一个键,如空格键,再按删除键【Backspace】,即可将字符串字段的【空值】修改为【空格】。

数字型字段直接输入【0】即可。

批量的话,可以使用字段计算器。

字符串型字段输入【""】,数字型字段输入【0】来消除空值。

另外,如果你装过了CC工具箱 的话,有一个**【字段数据清洗】**工具可以直接对所有字段进行批量处理。

相关推荐
杨超越luckly2 天前
ArcGISPro应用指南:ArcGISPro制图全流程详解
arcgis·信息可视化·gis·制图·arcgispro
~央千澈~3 天前
UniApp完全支持快应用QUICKAPP-以及如何采用 Uni 模式开发发行快应用优雅草卓伊凡
arcgis
敲敲敲-敲代码3 天前
【ArcGIS10.2】网络数据集构建---最短路径分析
网络·arcgis
人工智能教学实践3 天前
【基于Echarts的地图可视化】
arcgis
Cacciatore->3 天前
Electron 快速上手
javascript·arcgis·electron
南草徽13 天前
arcgis分割 (Split)
arcgis
野生工程师15 天前
【ArcGIS】在线影像底图调用
arcgis
装疯迷窍_A15 天前
ARCGIS国土超级工具集1.6更新说明
arcgis·插件·尖锐角·电子报盘·批量分割矢量
@菜菜_达16 天前
AgGrid学习笔记
笔记·学习·arcgis
德育处主任Pro16 天前
AntV G 入门教程
arcgis