Foxtable(狐表)用户栏目专家坐堂 → 多字段与统计问题


  共有3096人关注过本帖树形打印复制链接

主题:多字段与统计问题

帅哥哟,离线,有人找我吗?
lgz518
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1271 积分:8670 威望:0 精华:0 注册:2019/6/13 9:57:00
多字段与统计问题  发帖心情 Post By:2020/6/1 0:29:00 [只看该作者]

多值字段与统计

普通用户请忽略本节内容。

本节知识的一个要点是Dictionary,如果你对其已经生疏,请先温习一下。
这是一个很好的使用字典的例子,希望大家能细细体会。

假定有一个下图所示的产量登记表,其中员工工号列是多值字段

图片点击可在新窗口打开查看

现在需要统计每个员工加工的产品数量,同一个产品,如果有多个员工参与加工,那么产量平分。

显然这样的统计,用传统的统计工具是无法实现的,我们只能手工编码统计,不过代码也不算复杂:

'生成统计表的结构
Dim
 dt As DataTable
Dim
 dtb As New DataTableBuilder("统计")
dtb.AddDef(
"工号"Gettype(String), 16)
dtb
.AddDef("数量"Gettype(Double))
dt
 = dtb.Build()
'开始逐行累加统计

Dim 
lst As New Dictionary(of String ,DataRow'定义一个字典,用于检索每个员工在统计表中对应的行
For Each 
dr1 As DataRow In DataTables("产量登记").DataRows
    If 
dr1.IsNull("员工工号") = False Then '如果工号列不为空
        Dim 
nms() As String = dr1("员工工号").Split(","'将工号列内容拆分成数组
        Dim 
v As Double = dr1("数量") / nms.Length '获得平均之后每个工号的生产数量
        For Each 
nm As String In nms '遍历参与加工此产品的每个工号
            Dim 
dr2 As DataRow
            If 
lst.ContainsKey(nm'如果集合中包括此工号对应的行
                
dr2lst(nm'将此行赋值给变量dr2
            Else

                dr2
 = dt.AddNew() '否则增加一行.
                
dr2("工号") = nm '新增行的工号列设置为此工号
                
lst.add(nm,dr2'将新增行添加到字典中,以便接下来检索
            End If

            dr2
("数量") = dr2("数量") + v '加上平均后的产量
        Next
    End If
Next

在命令窗口执行上面的代码,即可得到如下统计结果:

图片点击可在新窗口打开查看

如果要统计每个员工加工不同产品的数量,代码只需稍微调整一下:

'生成统计表的结构
Dim
 dt As DataTable
Dim
 dtb As New DataTableBuilder("统计")
dtb.AddDef(
"工号"Gettype(String), 16)
dtb.AddDef(
"产品"Gettype(String), 16)
dtb.AddDef(
"数量"Gettype(Double))
dt = dtb.Build()

'开始逐行累加统计

Dim
 lst As New Dictionary(of String ,DataRow'定义一个字典,用于检索每个员工在统计表中对应的行
For
 Each dr1 As DataRow In DataTables("产量登记").DataRows
    If
 dr1.IsNull("员工工号") = False Then 
'如果工号列不为空
    
    Dim nms() As String = dr1("员工工号").Split(","'将工号列内容拆分成数组
    
    Dim v As Double = dr1("数量") / nms.Length '获得平均之后每个工号的生产数量
        For
 Each nm As String In nms
 '遍历参与加工此产品的每个工号
            
Dim dr2 As DataRow
            Dim
 key As String = nm & "|" & dr1("产品"
'这里是关键,由工号和产品组成字典的关键词.
            
If lst.ContainsKey(key) '如果集合中包括此关键词对应的行
                dr2= lst(key) 
'将此行赋值给变量dr2
            
Else
                dr2 = dt.AddNew() 
'否则增加一行.
                dr2(
"工号") = nm '新增行的工号列设置为此工号
                dr2(
"产品") = dr1("产品"'设置增行的产品
                lst.add(key,dr2) 
'将新增行添加到字典中,以便接下来检索
            
End If
        dr2(
"数量") = dr2("数量") + v '加上平均后的产量
        
Next
    
End If
Next
MainTable = Tables(
"统计")



问题:上面是帮助实例,它是用平均计算员工产量,但有时不能平均分,而按一定比例的分


1,不是平均分,如何按分配表的比例进行统计,“分配表”的字段有“员工工号,员工姓名,分配比例”?

2,如果不用跨表,分配表来取值,是直接在“产量登记”表的“员工工号”写明,如“员工工号”0002/50,0003/10,是工号/产量,这类方法计算?





 回到顶部
帅哥哟,离线,有人找我吗?
sloyy
  2楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2193 积分:13914 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2020/6/1 2:29:00 [只看该作者]

For Each dr1 As DataRow In DataTables("产量登记").DataRows
    If
 dr1.IsNull("员工工号") = False Then 
'如果工号列不为空
    
    Dim nms() As String = dr1("员工工号").Split(","'将工号列内容拆分成数组
    
   ' Dim v As Double = dr1("数量") / nms.Length '获得平均之后每个工号的生产数量
        For
 Each nm As String In nms
 '遍历参与加工此产品的每个工号
    Dim dr3 As DataRow 
dr3=datatables("分配表").find("员工工号='" & nm &"'")
            Dim dr2 As DataRow
            Dim
 key As String = nm & "|" & dr1("产品"
'这里是关键,由工号和产品组成字典的关键词.
            
If lst.ContainsKey(key) '如果集合中包括此关键词对应的行
                dr2= lst(key) 
'将此行赋值给变量dr2
            
Else
                dr2 = dt.AddNew() 
'否则增加一行.
                dr2(
"工号") = nm '新增行的工号列设置为此工号
                dr2(
"产品") = dr1("产品"'设置增行的产品
                lst.add(key,dr2) 
'将新增行添加到字典中,以便接下来检索
            
End If
        dr2(
"数量") = dr2("数量") +dr1("数量")*dr3("分配比例")  '加上每个工号的生产数量
        
Next
    
End If
Next

 回到顶部
帅哥哟,离线,有人找我吗?
lgz518
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1271 积分:8670 威望:0 精华:0 注册:2019/6/13 9:57:00
  发帖心情 Post By:2020/6/1 17:15:00 [只看该作者]

如何用工号/产量,实现计算,员工产量?
在“产量登记”表的“员工工号”写明,“员工工号”0002/50,0003/10,是工号/产量,

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111414 积分:567140 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/6/1 17:22:00 [只看该作者]

请上传实例说明问题

 回到顶部
帅哥哟,离线,有人找我吗?
lgz518
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1271 积分:8670 威望:0 精华:0 注册:2019/6/13 9:57:00
  发帖心情 Post By:2020/6/1 18:24:00 [只看该作者]

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:多值字段与统计.foxdb


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111414 积分:567140 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/6/1 20:14:00 [只看该作者]

需要怎么计算,得到什么结果?手工填写结果截图看看

 回到顶部
帅哥哟,离线,有人找我吗?
lgz518
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1271 积分:8670 威望:0 精华:0 注册:2019/6/13 9:57:00
  发帖心情 Post By:2020/6/2 10:48:00 [只看该作者]

不是平均统计和跨表比配统计,是当前的表,员工工号字段的员工工号和数量计算员工的产量,如下图

图片点击可在新窗口打开查看此主题相关图片如下:统计问题2.jpg
图片点击可在新窗口打开查看


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111414 积分:567140 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/6/2 11:21:00 [只看该作者]

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:多值字段与统计.zip


 回到顶部