ArcGIS中的空值问题

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


01、空值的表现形式

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

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

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

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

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


02、空值的产生

空值的产生途径很多。

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

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

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

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

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


03、空值可能引发的问题

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

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

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

这里的【NoneType】就是空值。

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

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

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


04、空值的处理

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

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

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

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

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

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

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

相关推荐
受伤的僵尸15 小时前
为什么Arcgis/Qgis里我的图是扁的
arcgis
weixin_贾18 小时前
ArcGIS+ENVI实战:从零制作生态影响评价专题图(以植被类型与土壤侵蚀为例)
arcgis·土地利用·dem·水文分析·土壤侵蚀·arcgis栅格·envi遥感影像
Q一件事3 天前
Arcgis出图出现横条/条纹问题的解决方案
arcgis
凌然先生4 天前
17.如何利用ArcGIS进行空间统计分析
经验分享·笔记·arcgis·电脑
GIS思维4 天前
ArcGIS图斑属性自动智能填写!告别手动低效输入
arcgis
ByteCraze5 天前
一文讲透 npm 包版本管理规范
前端·arcgis·npm
龙仔CLL5 天前
微前端乾坤vue3项目使用tinymce,通过npm,yarn,pnpm包安装成功,但是引用报错无法使用
javascript·arcgis·npm
Yolo566Q6 天前
空间数据采集与管理丨在 ArcGIS Pro 中利用模型构建器批处理多维数据
arcgis
网上邻居YY7 天前
Arcgis表格数据导入+可视化--小白教程(以景观多样性指数为例)
图像处理·计算机视觉·arcgis·excel转表
非科班Java出身GISer7 天前
ArcGIS JSAPI 学习教程 - 可视域分析图层介绍-创建与编辑
arcgis·arcgis 可视域分析·arcgis js 可视域·arcgis 可视域分析图层·arcgis js 可视域图层·arcgis 可视域