Foxtable(狐表)用户栏目专家坐堂 → 按条件进行物料需求运算


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

主题:按条件进行物料需求运算

帅哥哟,离线,有人找我吗?
骑单车的青蛙
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
按条件进行物料需求运算  发帖心情 Post By:2015/4/27 15:05:00 [显示全部帖子]

请问谁能帮我,下面是我做的表,物料需求编码帮我加个条件,就“销售记录”的销售订单号计算相应的物料需求
[此贴子已经被作者于2015/4/27 15:05:05编辑过]

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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
按条件进行物料需求运算  发帖心情 Post By:2015/4/27 15:10:00 [显示全部帖子]

请帮我改一下代码,按销售记录内的"销售订单号",输入某个“销售订单号”,物料需求就只计算这个订单的物料需求数量

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:eageboot_管理平台.table

[此贴子已经被作者于2015/4/27 15:20:20编辑过]

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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
  发帖心情 Post By:2015/4/27 15:25:00 [显示全部帖子]


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

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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
  发帖心情 Post By:2015/4/27 15:50:00 [显示全部帖子]


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

就是帮我把下面的代码更改一下,加个条件,如过图文本框内输入入“销售订单号",如果在“销售记录”找到相应的“销售订单号”那么计算此订单号需求物料数量()

Dim dic As new Dictionary(of String,Integer)
Dim xs As String
For Each dr1 As DataRow In DataTables("销售记录").DataRows
    For Each dr2 As DataRow In DataTables("产品BOM").Select("[产品配置号] = '" & dr1("产品配置号") & "'")
        Dim nm As String = dr2("零件代码")
        Dim vl As Integer = dr1("销售数量") * dr2("单机数量")
        If dic.ContainsKey(nm) = False
            dic.Add(nm,vl)
        Else
            dic(nm) = dic(nm)+ vl
        End If
    Next
Next
For Each key As String In dic.keys
    Dim dr As DataRow
    dr = DataTables("物料需求").Find("零件代码 Is Null ")
    If dr Is Nothing Then
        dr = DataTables("物料需求").AddNew()
    End If
    dr("零件代码") = key
    dr("数量") = dic(key)
Next


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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
  发帖心情 Post By:2015/4/27 19:41:00 [显示全部帖子]

Dim dic As new Dictionary(of String,Integer)
Dim xs As String
For Each dr1 As DataRow In DataTables("销售记录").select("销售订单号='" & e.form.controls("ComboBox1").text & "'")
For Each dr2 As DataRow In DataTables("产品BOM").Select("[产品配置号] = '" & dr1("产品配置号") & "'")
Dim nm As String = dr2("零件代码")
Dim vl As Integer = dr1("销售数量") * dr2("单机数量")
If dic.ContainsKey(nm) = False
dic.Add(nm,vl)
Else
dic(nm) = dic(nm)+ vl
End If
Next
Next
For Each key As String In dic.keys
Dim dr As DataRow
dr = DataTables("物料需求").Find("零件代码 Is Null ")
If dr Is Nothing Then
dr = DataTables("物料需求").AddNew()
End If
dr("零件代码") = key
dr("数量") = dic(key)
Next

 

这段代码,销售记录内有几个订单记录就计算几次,如有3条,就计算3次,能不能用IF   end条件,这段代码重复计算


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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
  发帖心情 Post By:2015/4/28 8:14:00 [显示全部帖子]

上面代码重复运算,能不能帮我改一下

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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
  发帖心情 Post By:2015/4/28 9:21:00 [显示全部帖子]

BIN你好,

这样了,我销售记录内,一个“销售订单号”对应了三条产品记录,而在“物料需求表”内,我选择“销售订单号”,点击“需求统计"时,运算三次,(我试过,有几条相同“销售订单号”的销售记录,就统计几次,


图片点击可在新窗口打开查看此主题相关图片如下:1.png
图片点击可在新窗口打开查看
[此贴子已经被作者于2015/4/28 9:21:05编辑过]

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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
  发帖心情 Post By:2015/4/28 9:23:00 [显示全部帖子]

我把附件上传一下,你看下就明白了

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:eageboot_管理平台.table


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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
  发帖心情 Post By:2015/4/28 9:38:00 [显示全部帖子]

统计输入"销售订单号"对应的物料需求,但现在,物料需求表内统计一次是对的,但是统计多次就不对啊,

  例如:车架,按销售订单数量计算数量应是168个,现在有三条相同“销售订单号”销售记录,就变成,168+168+168


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

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

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


加好友 发短信
等级:婴狐 帖子:62 积分:538 威望:0 精华:0 注册:2015/3/20 7:57:00
  发帖心情 Post By:2015/4/28 10:01:00 [显示全部帖子]

我修改了,好像出现问题了,我不会VBA,能帮我改到位, 


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

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