Foxtable(狐表)用户栏目专家坐堂 → 组合统计


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

主题:组合统计

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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
组合统计  发帖心情 Post By:2014/6/26 20:40:00 [显示全部帖子]

老师:你好!

     在组合统计结果中增加一个期初数量和期初金额列
Dim Filter As String

With e.Form.Controls("日期")
    If .Value Is Nothing Then
        Return
    End If
End With
Dim curD As Date=e.Form.Controls("日期").Value '当前日期
Dim lastD As Date =e.Form.Controls("日期").Value.AddMonths(-1) '上一个月的日期
Dim lastD2 As New Date(lastD.Year, lastD.Month, Date.DaysInMonth(lastD.Year,lastD.Month)) '上个月的最后一天

If Filter >"" Then
    Filter = Filter & " And "
End If
Filter = Filter & "日期 <= #" & curD & "#" & " And 日期 > #" & lastD2 & "#"

Dim bd1 As New GroupTableBuilder("统计表1",DataTables("进货"))
Dim dt1 As fxDataSource
bd1.Groups.AddDef("型号") '根据型号分组
bd1.Totals.AddDef("进货_数量","进货_数量") '对数量进行统计
bd1.Totals.AddDef("进货_金额","进货_金额") '对金额进行统计
bd1.Filter = Filter
dt1 = bd1.BuildDataSource()
Dim bd2 As New GroupTableBuilder("统计表2",DataTables("销售"))
Dim dt2  As fxDataSource
bd2.Groups.AddDef("型号") '根据型号分组
bd2.Totals.AddDef("销售_数量","销售_数量") '对数量进行统计
bd2.Totals.AddDef("销售_金额","销售_金额") '对金额进行统计
bd2.Totals.AddExp("期初_金额","期初_金额") '对金额进行统计
bd2.Filter = Filter
dt2 = bd2.BuildDataSource()
Dim bd3 As New GroupTableBuilder("统计表3",DataTables("退货"))
Dim dt3 As fxDataSource
bd3.Groups.AddDef("型号") '根据型号分组
bd3.Totals.AddDef("退货_数量","退货_数量") '对数量进行统计
bd3.Totals.AddDef("退货_金额","退货_金额") '对金额进行统计
bd3.Filter = Filter
dt3 = bd3.BuildDataSource()
dt1.Combine("型号",dt2,"型号") '将销售统计数据组合到进货统计数据
dt1.Combine("型号",dt3,"型号") '将退货统计数据组合到进货统计数据
Tables("统计_Table1").DataSource = dt1 '将统计结果绑定到Table

With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("期初_数量",Gettype(Double), "IsNull([进货_数量],0) - ISNULL([销售_数量],0) - ISNULL([退货_数量],0)")
    .Add("期初_金额",Gettype(Double), "IsNull([进货_金额],0) - ISNULL([销售_金额],0) - ISNULL([退货_金额],0)")
End With
'上面代码为统计期初数据

'下面代码为统计当期发生额
Filter = Filter & "日期 <= #" & curD & "#" 

Dim bd1 As New GroupTableBuilder("统计表1",DataTables("进货"))

Dim dt1 As fxDataSource
bd1.Groups.AddDef("型号") '根据型号分组
bd1.Totals.AddDef("进货_数量","进货_数量") '对数量进行统计
bd1.Totals.AddDef("进货_金额","进货_金额") '对金额进行统计
bd1.Filter = Filter
dt1 = bd1.BuildDataSource()
Dim bd2 As New GroupTableBuilder("统计表2",DataTables("销售"))
Dim dt2  As fxDataSource
bd2.Groups.AddDef("型号") '根据型号分组
bd2.Totals.AddDef("销售_数量","销售_数量") '对数量进行统计
bd2.Totals.AddDef("销售_金额","销售_金额") '对金额进行统计
bd2.Totals.AddExp("期初_金额","期初_金额") '对金额进行统计
bd2.Filter = Filter
dt2 = bd2.BuildDataSource()

Dim bd3 As New GroupTableBuilder("统计表3",DataTables("退货"))
Dim dt3 As fxDataSource
bd3.Groups.AddDef("型号") '根据型号分组
bd3.Totals.AddDef("退货_数量","退货_数量") '对数量进行统计
bd3.Totals.AddDef("退货_金额","退货_金额") '对金额进行统计
bd3.Filter = Filter
dt3 = bd3.BuildDataSource()

dt1.Combine("型号",dt2,"型号") '将销售统计数据组合到进货统计数据
dt1.Combine("型号",dt3,"型号") '将退货统计数据组合到进货统计数据
Tables("统计_Table1").DataSource = dt1 '将统计结果绑定到Table

With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("库存_数量",Gettype(Double), "IsNull([期初_数量],0) - IsNull([进货_数量],0) - ISNULL([销售_数量],0) - ISNULL([退货_数量],0)")
    .Add("库存_金额",Gettype(Double), "IsNull([期初_金额],0) - IsNull([进货_金额],0) - ISNULL([销售_金额],0) - ISNULL([退货_金额],0)")
End With
Tables("统计_Table1").SetColVisibleWidth("型号|80|期初_数量|80|期初_金额|80|进货_数量|80|进货_金额|80|销售_数量|80|进货_金额|80|退货_数量|80|退货_金额|80|库存_数量|80|库存_金额|80")
怎样把期初和当期二次统计合并?

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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 8:17:00 [显示全部帖子]

例子在Foxtable的CaseStudy文件夹:组合统计结果.Table

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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 9:21:00 [显示全部帖子]

例子
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:组合统计结果.table


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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 10:08:00 [显示全部帖子]

期初是指“e.Form.Controls("日期")”的上一个月(包含)的日期。

不好意思,请问是做财务的吗?
财务上大多是以年、月统计。

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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 10:55:00 [显示全部帖子]

  在组合统计结果中增加一个期初数量和期初金额列
显示:
Tables("统计_Table1").SetColVisibleWidth("型号|80|期初_数量|80|期初_金额|80|进货_数量|80|进货_金额|80|销售_数量|80|进货_金额|80|退货_数量|80|退货_金额|80|库存_数量|80|库存_金额|80")
怎样把期初和当期二次统计合并?


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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 11:47:00 [显示全部帖子]

显示的表格格式是这样,但统计出的期初数和期末数不正确。期初数是指截止到当前日期的上一期库存数,当期库存数是上一期库存数+当期进货数-当期销售数-当期退货数。
Dim Filter As String
With e.Form.Controls("日期")
    If .Value Is Nothing Then
        Return
    End If
End With

Dim curD As Date=e.Form.Controls("日期").Value '当前日期
Filter = Filter & "日期 <= #" & curD & "#"

Dim bd1 As New GroupTableBuilder("统计表1",DataTables("进货"))
Dim dt1 As fxDataSource
bd1.Groups.AddDef("型号") '根据型号分组
bd1.Totals.AddDef("进货_数量","进货_数量") '对数量进行统计
bd1.Totals.AddDef("进货_金额","进货_金额") '对金额进行统计
bd1.Filter = Filter
dt1 = bd1.BuildDataSource()
Dim bd2 As New GroupTableBuilder("统计表2",DataTables("销售"))
Dim dt2  As fxDataSource
bd2.Groups.AddDef("型号") '根据型号分组
bd2.Totals.AddDef("销售_数量","销售_数量") '对数量进行统计
bd2.Totals.AddDef("销售_金额","销售_金额") '对金额进行统计
bd2.Filter = Filter
dt2 = bd2.BuildDataSource()

Dim bd3 As New GroupTableBuilder("统计表3",DataTables("退货"))
Dim dt3 As fxDataSource
bd3.Groups.AddDef("型号") '根据型号分组
bd3.Totals.AddDef("退货_数量","退货_数量") '对数量进行统计
bd3.Totals.AddDef("退货_金额","退货_金额") '对金额进行统计
bd3.Filter = Filter
dt3 = bd3.BuildDataSource()

dt1.Combine("型号",dt2,"型号") '将销售统计数据组合到进货统计数据
dt1.Combine("型号",dt3,"型号") '将退货统计数据组合到进货统计数据
Tables("统计_Table1").DataSource = dt1 '将统计结果绑定到Table
Dim lastD As Date = curD.AddMonths(-1) '上一个月的日期
Dim lastD2 As New Date(lastD.Year, lastD.Month, Date.DaysInMonth(lastD.Year,lastD.Month)) '上个月的最后一天
Filter = "日期 <= #" & curD & "#" & " And 日期  > #" & lastD & "#"
With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("期初_数量",Gettype(Double),"","期初_数量")
    .Add("期初_金额",Gettype(Double),"","期初_金额")

    '.Add("期初_数量",Gettype(Double),"","信息_期初数量")
    '.Add("期初_金额",Gettype(Double),"","信息_期初金额")
End With
For Each r As Row In Tables("统计_Table1").Rows
    r("期初_数量") = DataTables("进货").Compute("sum(进货_数量)", filter) - DataTables("销售").Compute("sum(销售_数量)", filter) - DataTables("退货").Compute("sum(退货_数量)", filter)
    r("期初_金额") = DataTables("进货").Compute("sum(进货_金额)", filter) - DataTables("销售").Compute("sum(销售_金额)", filter) - DataTables("退货").Compute("sum(退货_金额)", filter)
Next
With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("库存_数量",Gettype(Double), "IsNull([期初_数量],0) - IsNull([进货_数量],0) - ISNULL([销售_数量],0) - ISNULL([退货_数量],0)","库存_数量")
    .Add("库存_金额",Gettype(Double), "IsNull([期初_金额],0) - IsNull([进货_金额],0) - ISNULL([销售_金额],0) - ISNULL([退货_金额],0)","库存_金额")

    '.Add("库存_数量",Gettype(Double), "IsNull([期初_数量],0) - IsNull([进货_数量],0) - ISNULL([销售_数量],0) - ISNULL([退货_数量],0)","信息_当期数量")
    '.Add("库存_金额",Gettype(Double), "IsNull([期初_金额],0) - IsNull([进货_金额],0) - ISNULL([销售_金额],0) - ISNULL([退货_金额],0)","信息_当期金额")
End With
Tables("统计_Table1").SetColVisibleWidth("型号|80|期初_数量|80|期初_金额|80|进货_数量|80|进货_金额|80|销售_数量|80|销售_金额|80|退货_数量|80|退货_金额|80|库存_数量|80|库存_金额|80")

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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 12:48:00 [显示全部帖子]

出现:编译错误:未声明“日期”
        错误代码:Filter = Filter &  "日期 >= #" & lastD2 & "# & " And 日期 < #" & curD & "#"
       应该如何修改?
With e.Form.Controls("日期")
    If .Value Is Nothing Then
        Return
    End If
End With
Dim Filter As String
Dim curD As Date=e.Form.Controls("日期").Value '当前日期
Dim lastD As Date = curD.AddMonths(-1) '上一个月的日期
Dim lastD2 As New Date(lastD.Year, lastD.Month, Date.DaysInMonth(lastD.Year,lastD.Month)) '上个月的最后一天
'Filter = Filter & "日期 >= #" & lastD2 & "# & " And 日期 < #" & curD & "# "
Filter = Filter &  "日期 >= #" & lastD2 & "# & " And 日期 < #" & curD & "#"
Dim bd1 As New GroupTableBuilder("统计表1",DataTables("进货"))
Dim dt1 As fxDataSource
bd1.Groups.AddDef("型号") '根据型号分组
bd1.Totals.AddDef("进货_数量","进货_数量") '对数量进行统计
bd1.Totals.AddDef("进货_金额","进货_金额") '对金额进行统计
bd1.Filter = Filter
dt1 = bd1.BuildDataSource()
Dim bd2 As New GroupTableBuilder("统计表2",DataTables("销售"))
Dim dt2  As fxDataSource
bd2.Groups.AddDef("型号") '根据型号分组
bd2.Totals.AddDef("销售_数量","销售_数量") '对数量进行统计
bd2.Totals.AddDef("销售_金额","销售_金额") '对金额进行统计
bd2.Filter = Filter
dt2 = bd2.BuildDataSource()

Dim bd3 As New GroupTableBuilder("统计表3",DataTables("退货"))
Dim dt3 As fxDataSource
bd3.Groups.AddDef("型号") '根据型号分组
bd3.Totals.AddDef("退货_数量","退货_数量") '对数量进行统计
bd3.Totals.AddDef("退货_金额","退货_金额") '对金额进行统计
bd3.Filter = Filter
dt3 = bd3.BuildDataSource()

dt1.Combine("型号",dt2,"型号") '将销售统计数据组合到进货统计数据
dt1.Combine("型号",dt3,"型号") '将退货统计数据组合到进货统计数据
Tables("统计_Table1").DataSource = dt1 '将统计结果绑定到Table
'Dim lastD As Date = curD.AddMonths(-1) '上一个月的日期
'Dim lastD2 As New Date(lastD.Year, lastD.Month, Date.DaysInMonth(lastD.Year,lastD.Month)) '上个月的最后一天
'Filter = "日期 <= #" & curD & "#" & " And 日期  > #" & lastD & "#"
Filter = "日期 <=  #" & lastD & "#"
'Filter = Filter & "日期 <= #" & curD & "# "
With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("期初_数量",Gettype(Double),"","信息_期初数量")
    .Add("期初_金额",Gettype(Double),"","信息_期初金额")
End With
For Each r As Row In Tables("统计_Table1").Rows
    r("期初_数量") = DataTables("进货").Compute("sum(进货_数量)", filter) - DataTables("销售").Compute("sum(销售_数量)", filter) - DataTables("退货").Compute("sum(退货_数量)", filter)
    r("期初_金额") = DataTables("进货").Compute("sum(进货_金额)", filter) - DataTables("销售").Compute("sum(销售_金额)", filter) - DataTables("退货").Compute("sum(退货_金额)", filter)
Next
With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("库存_数量",Gettype(Double), "IsNull([期初_数量],0) - IsNull([进货_数量],0) - ISNULL([销售_数量],0) - ISNULL([退货_数量],0)","信息_当期数量")
    .Add("库存_金额",Gettype(Double), "IsNull([期初_金额],0) - IsNull([进货_金额],0) - ISNULL([销售_金额],0) - ISNULL([退货_金额],0)","信息_当期金额")
End With
Tables("统计_Table1").SetColVisibleWidth("型号|80|进货_数量|80|进货_金额|80|销售_数量|80|销售_金额|80|退货_数量|80|退货_金额|80|期初_数量|80|期初_金额|80|库存_数量|80|库存_金额|80")


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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 14:07:00 [显示全部帖子]

With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("期初_数量",Gettype(Double),"","信息_期初数量")
    .Add("期初_金额",Gettype(Double),"","信息_期初金额")
End With
For Each r As Row In Tables("统计_Table1").Rows
    r("期初_数量") = DataTables("进货").Compute("sum(进货_数量)", filter) - DataTables("销售").Compute("sum(销售_数量)", filter) - DataTables("退货").Compute("sum(退货_数量)", filter)
    r("期初_金额") = DataTables("进货").Compute("sum(进货_金额)", filter) - DataTables("销售").Compute("sum(销售_金额)", filter) - DataTables("退货").Compute("sum(退货_金额)", filter)
期初数的统计少了个型号的条件,怎么加上?

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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 14:14:00 [显示全部帖子]

老师:你好!
     我是个会计,不懂编程,完全是在按示例搬,请帮帮忙改一下。

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


加好友 发短信
等级:二尾狐 帖子:553 积分:5327 威望:0 精华:0 注册:2011/6/7 13:33:00
  发帖心情 Post By:2014/6/27 14:37:00 [显示全部帖子]

 Filter = "日期 <=  #" & lastD & "#"

With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("期初_数量",Gettype(Double),"","信息_期初数量")
    .Add("期初_金额",Gettype(Double),"","信息_期初金额")
End With
For Each r As Row In Tables("统计_Table1").Rows

    Filter = Filter & " and 型号 = '" & r("型号") & "'"
    r("期初_数量") = DataTables("进货").Compute("sum(进货_数量)", filter) - DataTables("销售").Compute("sum(销售_数量)", filter) - DataTables("退货").Compute("sum(退货_数量)", filter)
    r("期初_金额") = DataTables("进货").Compute("sum(进货_金额)", filter) - DataTables("销售").Compute("sum(销售_金额)", filter) - DataTables("退货").Compute("sum(退货_金额)", filter)
Next


共有四行期初数,现在只能取到第一行的期初数,什么原因?


 回到顶部
总数 12 1 2 下一页