以文本方式查看主题 - Foxtable(狐表) (http://foxtable.com/bbs/index.asp) -- 专家坐堂 (http://foxtable.com/bbs/list.asp?boardid=2) ---- 减号报错 (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=194439) |
-- 作者:lisheng0613 -- 发布时间:2024/12/10 11:06:00 -- 减号报错 For Each dc As DataCol In DataTables("预算报表_table1").DataCols If dc.name = "预算类型" Then Continue For Else Dim r0 As Row = Tables("预算报表_table1").Rows(0) Dim r1 As Row = Tables("预算报表_table1").Rows(1) Dim r2 As Row = Tables("预算报表_table1").Rows(2) r0(dc.name) = r1(dc.name) - r2(dc.name) End If Next 减号报错,加号正常运算,为啥? 报错提示“从字符串“”到类型“double”的转换无效”
|
-- 作者:有点蓝 -- 发布时间:2024/12/10 11:16:00 -- 把"预算类型"列类型改为双精度 |
-- 作者:lisheng0613 -- 发布时间:2024/12/10 11:39:00 -- 老师,预算类型列是文本类型,不参与计算。 |
-- 作者:lisheng0613 -- 发布时间:2024/12/10 11:40:00 -- 而且,我测试过了,换成加号正常,减号就不行了 |
-- 作者:有点蓝 -- 发布时间:2024/12/10 11:48:00 -- 减号就是做减法,怎么会不参与计算?! 加号出来做加法,还可以用来合并字符串,所没有问题
|
-- 作者:lisheng0613 -- 发布时间:2024/12/10 11:50:00 -- If dc.name = "预算类型" Then Continue For 预算类型这一列,我是跳过去了吧。
|
-- 作者:lisheng0613 -- 发布时间:2024/12/10 11:52:00 -- 我的意思是原来没有 If dc.name = "预算类型" Then Continue For 这一段代码的时候,我看到加号是把字符合并了,所有加了这各代码,后面就正常运算了。不会出现字符相加的意思,但是减号不能达到这个效果
|
-- 作者:有点蓝 -- 发布时间:2024/12/10 11:57:00 -- 剩下的还有字符列吗 For Each dc As DataCol In DataTables("预算报表_table1").DataCols If dc.name = "预算类型" Then Continue For Else Dim r0 As Row = Tables("预算报表_table1").Rows(0) 这一句必须换行,不能和Else 同一行 Dim r1 As Row = Tables("预算报表_table1").Rows(1) Dim r2 As Row = Tables("预算报表_table1").Rows(2) r0(dc.name) = r1(dc.name) - r2(dc.name) End If Next
|
-- 作者:lisheng0613 -- 发布时间:2024/12/10 12:00:00 -- 是的,有一列隐藏列没看到。已经解决了,谢谢。 |