Foxtable(狐表)用户栏目专家坐堂 → [求助]水平表和垂直表转换


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

主题:[求助]水平表和垂直表转换

帅哥,在线噢!
有点蓝
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110766 积分:563762 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/11/6 11:11:00 [显示全部帖子]

Dim dtb As New DataTableBuilder("表B")
dtb.AddDef("学期", Gettype(String), 32)
dtb.AddDef("科目", Gettype(String), 32)
For Each v As String In DataTables("表A").GetValues("姓名")
    dtb.AddDef(v, Gettype(Double))
Next
dtb.Build()
For Each v As String In DataTables("表A").GetValues("学期")
    For Each dc As DataCol In DataTables("表A").datacols
        If dc.name <> "学期" AndAlso dc.name <> "姓名"
            Dim dr1 As DataRow = DataTables("表B").AddNew()
            dr1("学期") = v
            dr1("科目") = dc.name
            For Each v2() As String In DataTables("表A").GetValues("姓名|" & dc.name)
                dr1(v2(0)) = v2(1)
            Next
        End If
    Next
Next
MainTable = Tables("表B")

 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110766 积分:563762 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/11/6 13:48:00 [显示全部帖子]

请截图说明

 回到顶部
帅哥,在线噢!
有点蓝
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110766 积分:563762 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/11/6 14:36:00 [显示全部帖子]

Dim dtb As New DataTableBuilder("表B")
dtb.AddDef("学期", Gettype(String), 32)
dtb.AddDef("科目", Gettype(String), 32)
For Each v As String In DataTables("表A").GetValues("姓名")
    dtb.AddDef(v, Gettype(Double))
Next
dtb.AddDef("平均", Gettype(Double))
dtb.Build()
For Each v As String In DataTables("表A").GetValues("学期")
    For Each dc As DataCol In DataTables("表A").datacols
        If dc.name <> "学期" AndAlso dc.name <> "姓名"
            Dim dr1 As DataRow = DataTables("表B").AddNew()
            dr1("学期") = v
            dr1("科目") = dc.name
dim sum as double = 0
Dim Arys As List(Of String()) = DataTables("表A").GetValues("姓名|" & dc.name)
            For Each v2() As String In Arys
                dr1(v2(0)) = v2(1)
sum+=val(v2(1))
            Next
dr1("平均") = sum / Arys.count
        End If
    Next
Next
MainTable = Tables("表B")

 回到顶部
帅哥,在线噢!
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110766 积分:563762 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/11/6 17:15:00 [显示全部帖子]

Dim m1 As Double = Tables("统计表").rows(i,true)("数量")

 回到顶部