【Excel】公式报错#VALUE! 解决问题的过程好抓马

我不明白呀!!!

在研究考勤表的统计,需要将两个考勤机的数据合并,判断是否打卡以及打卡时间是否早于8:30。为此写了一个逻辑绝对正确的公式,结果却报#VALUE!

给你们看我的思路

我照着思路写出来的代码:

vbnet 复制代码
=IF(LEN(LEFT(INDEX(一号!$B$1:$AD$479,$R2,D$1),5))=1,
	IF(LEN(LEFT(INDEX(二号!$B$1:$AD$479,$R2,D$1),5))=1,
		"未签到",
		IF(LEFT(INDEX(二号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,
			"签到",
			"迟到"
		)
	),
	IF(LEN(LEFT(INDEX(二号!$B$1:$AD$479,$R2,D$1),5))=1,
		IF(LEFT(INDEX(一号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,
			"签到",
			"迟到"
		),
		IF(OR(
				LEFT(INDEX(一号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,
				LEFT(INDEX(二号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0
				),
			"签到",
			"迟到"
			)
		)
	)

神奇的是,公式按步骤计算的每一步都没有报错,这里贴一下最后一步的截图:

万幸的是我找到了症结,其中一个公式的结果会导致#VALUE!出现。

vbnet 复制代码
'错误代码
=IF(LEFT(INDEX(一号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,"签到","迟到")

毫无疑问,问题只能出现在LEFT(INDEX(赤峰!$B1:AD479,R2,D$1),5)-"8:30"<0这部分。

于是,我重新找了空格子手敲了这部分,没有问题,手敲了错误代码,正常显示。

多么诡异的一幕,我的眼睛看不出来啦,这到底哪里不一样?

vbnet 复制代码
'结果报错代码
=IF(LEFT(INDEX(一号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,"签到","迟到")
'结果正常代码
=IF(LEFT(INDEX(二号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,"签到","迟到")

原来的大公式里包含4个这样的公式部分,一个显示#VALUE!,一个正常显示,还有两个放在一个or函数里,是这么显示的。

多么抽象呀,我虽然不知道为什么错了,但我知道我只要把它重新书写一遍,就会没问题。

我错了!!!

重写一遍并没有用,**因为当获取的值为空时,取从左数5位字符(left函数)时,就埋下了错误的种子。**但令人不解的是公式的每一步计算都如我预期般显示应该的结果,只有到最后才会显示#VALUE!

left(0,5)的值是"0",空值里取出了数,而后续"0"-"8:30"的操作是正常的,但因为存在错误,不管后续结果如何,都会报错

于是我加了IFERROR套壳,期望错误发生的时候及时止步。真相却是公式计算的时候仍然无误,而结局总逃不过那个#VALUE!

原来如此!!!

我明白是书写的公式逻辑出现了问题,于是我重新梳理之后,诞生了正确的思路、正确的公式和正确的结果。

前面提到公式报错的症结在于做时间减法时出现了错误,所以得到的结果除了IF预设的两个真假对应的结果外,还有一个#VALUE!,基于此在IF外套壳IFERROR,可以有效将#VALUE!显示为第三种对应的结果。

这样,就人为地设置三种对应的结果,设未打卡状态为0,8:30以内打卡状态为1,8:30以外打卡状态为3,分别对两个打卡机进行判断。最后将它们的数据合并。两个打卡机只要有一个打卡就算打卡,所以未签到状态只能是0+0,而签到(8:30以内打卡)状态只能为0+1、1+0、1+1,介于1~2,迟到(8:30以外打卡)状态只能为3+0、3+1、0+3、1+3、3+3,介于3~6。

vbnet 复制代码
=IFS(
	IFERROR(
		IF(
			LEFT(
				INDEX(二号!$B$1:$AD$479,$R2,D$1),5
				)-"8:30"<0,
			1,
			3
			),
		0)
	+
	IFERROR(
		IF(
			LEFT(
				INDEX(一号!$B$1:$AD$479,$R2,D$1),5
				)-"8:30"<0,
			1,
			3),
		0)
	>2,
	"迟到",
	IFERROR(IF(LEFT(INDEX(二号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,1,3),0)+IFERROR(IF(LEFT(INDEX(一号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,1,3),0)
	>0,
	"签到",
	IFERROR(IF(LEFT(INDEX(二号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,1,3),0)+IFERROR(IF(LEFT(INDEX(一号!$B$1:$AD$479,$R2,D$1),5)-"8:30"<0,1,3),0)
	=0,
	"未签到"
	)
相关推荐
丁德双13 小时前
winform 加载 office excel 插入QRCode图片如何设定位置
c#·excel
IT铺子14 小时前
Excel 个人时间管理工具
excel
zxguan20 小时前
EasyExcel 学习之 导出 “提示问题”
学习·excel
忘忧记20 小时前
Excel批量转换不规范数据的教程
excel
神奇夜光杯21 小时前
Python酷库之旅-第三方库Pandas(200)
开发语言·人工智能·python·excel·pandas·标准库及第三方库·学习与成长
火星技术1 天前
Excel快速转换文档word工具
word·excel
 嘘 1 天前
文件操作:Xml转Excel
xml·python·excel
Mr。轩。1 天前
cn.afterturn.easypoi.exception.excel.ExcelExportException: Excel导出错误 -> 修正过程。
java·excel·导出
大哇唧2 天前
python批量合并excel文件
开发语言·python·excel
IT铺子2 天前
Excel 数据分析高级建模指南
excel