以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- [求助]数据计算问题代码 (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=50425) |
-- 作者:hrw68529 -- 发布时间:2014/5/6 17:16:00 -- [求助]数据计算问题代码 请各位老大看看,哪有毛病了,目的是在表“笔试成绩”中的列有:笔试成绩、加权系数、本场面试成绩、面试成绩、总成绩,之间的关系是:如果有加权系数的,面试成绩=加权系数*本场面试成绩;如果没有加权系数的,面试成绩=本场面试成绩;总成绩=笔试成绩*0.5+面试成绩*0.5,下述代码不知道出错在哪,只计算有加权系数的,不计算没有加权系数的,谢谢 If e.DataRow("加权系数") IsNot Nothing Then e.DataRow("面试成绩") = Round2(e.DataRow("加权系数")*e.DataRow("本场面试成绩"),2) Else e.DataRow("面试成绩") = e.DataRow("本场面试成绩") e.DataRow("总成绩") = Round2(e.DataRow("笔试成绩")*0.5 + e.DataRow("面试成绩")*0.5,2) End If |
-- 作者:Bin -- 发布时间:2014/5/6 17:22:00 -- If e.DataRow("加权系数") IsNot Nothing Then e.DataRow("面试成绩") = Round2(e.DataRow("加权系数")*e.DataRow("本场面试成绩"),2) Else 在这里加入 messagebox.show(1) 看看是否有运行到这里 e.DataRow("面试成绩") = e.DataRow("本场面试成绩") e.DataRow("总成绩") = Round2(e.DataRow("笔试成绩")*0.5 + e.DataRow("面试成绩")*0.5,2) End If
|
-- 作者:hrw68529 -- 发布时间:2014/5/6 17:29:00 -- 上例子:请指导。 |
-- 作者:tianyumgw -- 发布时间:2014/5/6 17:44:00 -- 请问下载后怎样打开你的文件 |
-- 作者:有点甜 -- 发布时间:2014/5/6 18:05:00 -- 如下代码,你记得把面试成绩和总成绩改成数据列,而不是表达式列
If e.DataCol.Name = "加权系数" Then |
-- 作者:hrw68529 -- 发布时间:2014/5/7 7:57:00 -- 甜总,按上述代码,没有加权系数的,能计算出总成绩,有加权系数的,计算不出总成绩,怎么回事 |
-- 作者:lsy -- 发布时间:2014/5/7 8:13:00 -- If e.DataCol.Name = "加权系数" Then If e.DataRow.IsNull("加权系数") = False Then e.DataRow("面试成绩") = Round2(e.DataRow("加权系数")*e.DataRow("本场面试成绩"),2) Else e.DataRow("面试成绩") = e.DataRow("本场面试成绩") End If e.DataRow("总成绩") = Round2(e.DataRow("笔试成绩")*0.5 + e.DataRow("面试成绩")*0.5,2) End If |
-- 作者:hrw68529 -- 发布时间:2014/5/7 8:39:00 -- 老狐爸在不,round2,不能严格的四舍不入,还需加上+0.0000001,是真的吗 |
-- 作者:有点甜 -- 发布时间:2014/5/7 9:12:00 -- 以下是引用hrw68529在2014-5-7 8:39:00的发言:
老狐爸在不,round2,不能严格的四舍不入,还需加上+0.0000001,是真的吗
round不是严格四舍五入;
round2是严格四舍五入。 |
-- 作者:hrw68529 -- 发布时间:2014/5/7 9:34:00 -- 如下例:Output.Show(Round2(56.35 * 0.5 + 81.22*0.5,2)),计算出的数为:68.785,保留两位小数应为68.79,但在命令窗口中执行为68.78,这是怎么回事? |