以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- [求助]能否在交叉表的垂直分组列中增加列(已解决) (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=11157) |
||||
-- 作者:yyzlxc -- 发布时间:2011/7/10 17:36:00 -- [求助]能否在交叉表的垂直分组列中增加列(已解决) 项目中用代码生成交叉统计(表年度汇总),想在垂直分组列中再增加二列,分别为人均加工费(加工费/月均人数)和其环比,代码应如何修改?请各位老师指教。谢谢!!
附上代码如下: \'读取ComboBox2中的年份 Dim k1 As String ="加工费_" r.DataTable.DataCols.Add("年人均加工费", Gettype(Double),"iif(合计_年均人数=0,null,合计_加工费/合计_年均人数)")
[此贴子已经被作者于2011-7-28 18:54:01编辑过]
|
||||
-- 作者:狐狸爸爸 -- 发布时间:2011/7/11 7:11:00 -- Dim sql As String = "Select 报表年月,日期,单位,Sum(加工费) As 加工费,Sum(投工) As 投工,Sum(加工费)/Sum(投工) As 人均加工费 FROM {日报源表} WHERE Year(日期) = \'" & nf & "\' Group By 报表年月,日期,单位 ORDER BY 单位,日期,报表年月"
剩下的你应该可以自己处理了。 [此贴子已经被作者于2011-7-11 7:11:31编辑过]
|
||||
-- 作者:yyzlxc -- 发布时间:2011/7/11 9:11:00 -- 谢谢狐爸老师的指教,根据您的提示,已经在垂直分组中成功地增加了一列,但存在一点瑕疵,就是人均加工费的合计行的值应该是平均值,如何来实现? 其次,式中的Sum(加工费)/Sum(投工) As 人均加工费的计算结果与实际值有误差,原因是Sum(投工)不等于月均人数,如何用式中的b.Totals.AddDef("投工",AggregateEnum.Average,"月均人数")的值来替换Sum(投工)? 另外,在垂直分组列中,有没有办法对某一列(比如人均加工费)进行环比,这是统计分析的一个重要手段,还请狐爸老师费神,给予指教,再次感谢!!
此主题相关图片如下:a.png [此贴子已经被作者于2011-7-11 9:31:35编辑过]
|
||||
-- 作者:狐狸爸爸 -- 发布时间:2011/7/11 9:18:00 -- 看看这些内容能否帮助你:
http://help.foxtable.com/topics/2305.htm
|
||||
-- 作者:yyzlxc -- 发布时间:2011/7/11 10:01:00 -- 请狐爸老师看一下3楼新增的内容,谢谢!! |
||||
-- 作者:狐狸爸爸 -- 发布时间:2011/7/11 10:05:00 -- 我也没有办法,先得到基本统计结果,然后自己编码增加列和计算统计结果。 |
||||
-- 作者:yyzlxc -- 发布时间:2011/7/11 10:23:00 -- 谢谢狐爸老师。我先试做一个方案,再请狐爸老师指教!! |
||||
-- 作者:yyzlxc -- 发布时间:2011/7/12 8:39:00 -- 其中一段代码作调整后,生成表如下:
此主题相关图片如下:b.png |
||||
-- 作者:yyzlxc -- 发布时间:2011/7/12 8:45:00 --
此主题相关图片如下:a.png |
||||
-- 作者:狐狸爸爸 -- 发布时间:2011/7/12 8:46:00 -- 先查看表结构,看看到底是否有名为j的列。 |