Foxtable(狐表)用户栏目专家坐堂 → 生成帐页问题


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

主题:生成帐页问题

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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/10/13 9:14:00 [只看该作者]

 不要重置列啊

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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/10/13 9:15:00 [只看该作者]

 你重新计算就行啊。


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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/10/13 9:25:00 [只看该作者]

说了那么多,都白说了,哎

 

Tables("物料帐页").OpenView("1")
Dim t1 As Integer =  Environment.TickCount
e.Form.StopRedraw
SystemReady = False
DataTables("物料帐页").Datarows.Clear()
Dim f As New Filler
f.SourceTable = DataTables("物料明细") '指定数据来源
f.SourceCols = "物料分类,物料名称,型号规格,日期,月,日,单位,入仓_数量,入仓_金额,出仓_数量,出仓_金额" '指定数据来源列
f.DataTable = DataTables("物料帐页") '指定数据接收表
f.DataCols = "物料分类,物料名称,型号规格,日期,月,日,单位,入仓_数量,入仓_金额,出仓_数量,出仓_金额" '指定数据接收列
f.Distinct = False
f.Fill() '填充数据
SystemReady = True
'触发列计算库存_数量
e.Form.ResumeRedraw

Dim pdr As DataRow = Nothing
For Each dr As DataRow In DataTables("物料帐页").Select("", "物料,日期")
    If pdr Is Nothing OrElse pdr("物料") <> dr("物料") Then
        pdr = dr
        dr("库存_数量") = dr("入仓_数量") - dr("出仓_数量")
        dr("库存_金额") = dr("入仓_金额") - dr("出仓_金额")
    Else
        dr("库存_数量") = pdr("库存_数量") + dr("入仓_数量") - dr("出仓_数量")
        dr("库存_金额") = pdr("库存_金额") + dr("入仓_金额") - dr("出仓_金额")
    End If
Next

Dim t2 As Integer =  Environment.TickCount
MessageBox.Show("耗时 " & (t2-t1)/1000)


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


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2014/10/13 10:49:00 [只看该作者]

谢谢有点甜,你的代码与我的代码得到的结果有出入,图1是你给的代码的结果,图2是原代码的结果,对比手套 棉纱物料的库存_数量和库存_金额,我们仓管员要的是图2的效果。

图1 


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


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


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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/10/13 11:09:00 [只看该作者]

哦,代码写错了

 

Tables("物料帐页").OpenView("1")
Dim t1 As Integer =  Environment.TickCount
e.Form.StopRedraw
SystemReady = False
DataTables("物料帐页").Datarows.Clear()
Dim f As New Filler
f.SourceTable = DataTables("物料明细") '指定数据来源
f.SourceCols = "物料分类,物料名称,型号规格,日期,月,日,单位,入仓_数量,入仓_金额,出仓_数量,出仓_金额" '指定数据来源列
f.DataTable = DataTables("物料帐页") '指定数据接收表
f.DataCols = "物料分类,物料名称,型号规格,日期,月,日,单位,入仓_数量,入仓_金额,出仓_数量,出仓_金额" '指定数据接收列
f.Distinct = False
f.Fill() '填充数据
SystemReady = True
'触发列计算库存_数量
e.Form.ResumeRedraw

Dim pdr As DataRow = Nothing
For Each dr As DataRow In DataTables("物料帐页").Select("", "物料,日期")
    If pdr Is Nothing OrElse pdr("物料") <> dr("物料") Then
        dr("库存_数量") = dr("入仓_数量") - dr("出仓_数量")
        dr("库存_金额") = dr("入仓_金额") - dr("出仓_金额")
    Else
        dr("库存_数量") = pdr("库存_数量") + dr("入仓_数量") - dr("出仓_数量")
        dr("库存_金额") = pdr("库存_金额") + dr("入仓_金额") - dr("出仓_金额")
    End If
    pdr = dr 
Next

Dim t2 As Integer =  Environment.TickCount
MessageBox.Show("耗时 " & (t2-t1)/1000)


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


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2014/10/13 11:30:00 [只看该作者]

可以啦!谢谢有点甜。

 回到顶部
总数 26 上一页 1 2 3