以文本方式查看主题

-  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
--  
上例子:请指导。
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:面试登分系统_201405061给bin.zip



--  作者:tianyumgw
--  发布时间:2014/5/6 17:44:00
--  
请问下载后怎样打开你的文件
--  作者:有点甜
--  发布时间:2014/5/6 18:05: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("本场面试成绩")
        e.DataRow("总成绩") = Round2(e.DataRow("笔试成绩")*0.5 + e.DataRow("面试成绩")*0.5,2)
    End If
End If


--  作者: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,这是怎么回事?