以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  [求助]表事件中平均值计算  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=77236)

--  作者:huangfanzi
--  发布时间:2015/11/13 14:57:00
--  [求助]表事件中平均值计算
表事件DataColChanged

假定以下内容,三个硬度不一定会全部输入:

硬度1 硬度2 硬度3  平均硬度
100   100    130    110
120   130             125
150                      150

由于这个硬度要被别的表从后台调用,所以不能用表达式,请问老师这个平均值代码应该如何写。       
[此贴子已经被作者于2015/11/13 14:56:58编辑过]

--  作者:大红袍
--  发布时间:2015/11/13 15:02:00
--  

呃,直接相加相除。

 

If e.DataCol.Name Like "硬度*" Then
    Dim count As Integer = 0
    Dim sum As Double = 0
    For Each dc As DataCol In e.DataTable.datacols
        If dc.name Like "硬度*" AndAlso e.DataRow.isnull(dc.name) = False Then
            count += 1
            sum += e.DataRow(dc.name)
        End If
    Next
    If count > 0 Then
        e.DataRow("平均硬度") = sum / count
    Else
        e.DataRow("平均硬度") = Nothing
    End If
End If