1. 功能描述
  2. 代码实现
  3. 算法需求

功能描述

  
 
  在PDA上面,通过扫描订单号,查询该商品的款号,尺码,订单数;同时适配仓库库位商品【SKU】,显示该商品所在库位,库存数量,适配数。
  因为PDA界面小,所以对表格拆分显示为俩个,代码也相应复杂一些。
 
 
 

代码实现

  

        /// <summary>
        /// 读头数据处理
        /// </summary>
        private void HandleData(Symbol.Barcode.ReaderData TheReaderData)
        {
              //定单适配
            )
            {
                txtWmsNo.Text = TheReaderData.Text;

                BindOrderDetailGrid(txtWmsNo.Text.Trim());
                btnAdaptor_Click(null, null);
            }
        }    
     private void BindOrderDetailGrid(string wmsID)
        {
            lv_Order.Items.Clear();

            try
            {
                _allOrderDetail = _repository.GetOrderDetail(wmsID);
                if (_allOrderDetail.Any())
                {
                    foreach (OrderDetail detail in _allOrderDetail)
                    {
                        ListViewItem item = new ListViewItem();
                        item.SubItems[].Text = detail.StyleNo;
                        item.SubItems.Add(detail.Size);
                        item.SubItems.Add(detail.OrderNum.ToString());//订单数
                        lv_Order.Items.Add(item);
                    }
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show("查询出错:" + ex.Message);
                btnExit_Click(null, null);
            }
        }
     //批量适配
        private void btnAdaptor_Click(object sender, EventArgs e)
        {
            if (string.IsNullOrEmpty(txtWmsNo.Text.Trim()) || txtWmsNo.Text == "扫描WMS单号…")
            {
                MessageBox.Show("请先扫描wmsID。", "操作提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Asterisk, MessageBoxDefaultButton.Button1);
                return;
            }
            if (_repository.ExitsWmsID(txtWmsNo.Text.Trim()))
            {
                DialogResult result = MessageBox.Show("该单号已经适配过了,是否继续?", "操作提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Asterisk, MessageBoxDefaultButton.Button1);
                if (result != DialogResult.OK)
                {
                    lv_Adaptor.Items.Clear();
                    return;
                }
            }

            _differenceQty = ;
            _list.Clear();

            try{
                _goodList = _repository.GetGoodsList(string.Join(",",_allOrderDetail.Select(c=>"'"+c.StyleNo+"'").ToArray()));
             }
            catch (Exception ex)
            {
                MessageBox.Show("查询出错:" + ex.Message);
                btnExit_Click(null, null);
            }

            if (_goodList.Any())
            {
                _allOrderDetail.ForEach(order => BindAdaptorGrid(_goodList.Where(c => c.StyleNo == order.StyleNo).ToList(), order.Size, order.OrderNum, false));
            }

            if (_list.Any())
            {
                _list.ForEach(o => lv_Adaptor.Items.Add(o));

                btnSave.Enabled = true;
                lbl_difNum.Text = "总差异数:" + _differenceQty;
                lblMsg.Text = "适配成功,请保存!";
            }
            else
            {
                btnSave.Enabled = false;
                lblMsg.Text = "适配失败,请先维护库存!";
            }
        }
        /// <summary>
        /// 绑定适配表
        /// 如果数量相等,则按照库位匹配
        /// </summary>
        /// <param name="orderNum">订单数</param>
        /// <param name="isSingle">是否单款</param>
        private void BindAdaptorGrid(List<PDA_TGoods> goodsByStyleNo,string size,int orderNum,bool isSingle)
        {
            lv_Adaptor.Items.Clear();
            lblMsg.Text = string.Empty;

            _orderNum = orderNum;

            List<GoodsSummary> summary_goods = GetGoodsSummary(goodsByStyleNo);

            if (summary_goods.Any())
            {
                int stockSumNum = goodsByStyleNo.Count();        //库存数总和
                bool isBreak = false;

                //差异数算法:[订单数>=库存数总和-->差异数=订单数-库存数;订单数<库存数总和-->差异数=0]
                );
                _differenceQty += singleDifNum;
                if (isSingle)
                    lbl_difNum.Text = "单款差异:" + singleDifNum;

                foreach (var g in summary_goods)
                {
                    ListViewItem item = new ListViewItem();
                    item.SubItems[].Text = g.StyleNo;      //库位
                    item.SubItems.Add(g.StockNo.ToString()); //库存数
                    item.SubItems.Add(g.SkuNum.ToString()); //库存数   

                    //适配数算法:
                    //(1)订单数>=库存数总和-->适配数=库存数;
                    //(2)订单数<库存数总和-->适配数=任意库位的数量的分配(必须=订单数)
                    ;
                    if (_orderNum >= stockSumNum)
                        adaptorNum = g.SkuNum;
                    else
                        adaptorNum = GetAdaptorNum(_orderNum, g.SkuNum, out isBreak);  

                    item.SubItems.Add(adaptorNum.ToString());
                    //item.SubItems.Add(g.Sku);         //条码[不可见]
                    item.SubItems.Add(size);          //尺码[不可见]

                    if (isSingle)
                       lv_Adaptor.Items.Add(item);
                    else
                        _list.Add(item);

                    if (isBreak) break;//适配到,则不再进行其他库位的适配
                }
            }
        }

        //计算适配数
        private int GetAdaptorNum(int orderNum, int stockNum,out bool isBreak)
        {
            ;
            if (orderNum >= stockNum)
            {
                adptorNum = stockNum;
                isBreak = false;
            }
            else
            {
                adptorNum = _orderNum;
                isBreak = true;
            }

            _orderNum = _orderNum - stockNum;

            )
                isBreak = true;

            return adptorNum;
        }
     /// <summary>
        /// 按款汇总商品总数,并做排序
        /// </summary>
        /// <param name="PDA_TGoods"></param>
        /// <returns></returns>
        private static List<GoodsSummary> GetGoodsSummary(List<PDA_TGoods> goods)
        {
            List<GoodsSummary> summary_goods = new List<GoodsSummary>();
            foreach (var g in goods.GroupBy(o => new { o.StockNo, o.StyleNo }))
            {
                GoodsSummary gt = new GoodsSummary();
                gt.SkuNum = g.Count();
                gt.StockNo = g.First().StockNo;
                gt.StyleNo = g.First().StyleNo;
                summary_goods.Add(gt);
            }

            //库存量大优先;同等数量,库位优先策略
            return summary_goods.OrderByDescending(o => o.SkuNum).ThenBy(o => o.StockNo).ToList();
        }
 

算法需求

    (1)订单数>=库存数总和 则 适配数 = 库存数;

         (2)订单数<库存数总和  则 适配数 = 任意库位的数量的分配(必须=订单数)

        (3)库存量大的库位优先适配;同等数量的库位,库位编号小的优先适配策略

 
 
 
 

PDA库位商品出库适配算法的更多相关文章

  1. ERP库位分布看板(库位管理)

    客户正在使用的看板管理,根据厂家需求,做的二次开发. 一:看板效果 二:客户需求 1.客户需求:XX是一家汽车零部件(胶管,硅胶管等)的生产厂家,因此对原料,半成品的有效期有严格的要求. 多次调研得知 ...

  2. 127_Power Pivot&Power BI DAX计算订单商品在库时间(延伸订单仓储费用)

    博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 前面已经写过一个先进先出的库龄案例,在业务发生又有这样一个需求:先进先出前提,需要按照订单计算每个商品在库时间, ...

  3. 关于推荐库位 java前端与SQL语句后面的结合

    ----------------------------------------------------------------------------------- select a1.id,a1. ...

  4. k3 cloud成本调整单提示期末余额不存在调整单分录的维度,请先出库核算确认是否存在核算维度的数据

    成本调整单提示期末余额不存在调整单分录的维度,请先出库核算确认是否存在核算维度的数据,如下图所示: 解决办法:先做出库核算,然后做成本调整单,再做出库核算(出库成本核算)

  5. 用友CDM系统“货位间商品移库单(一步)”表体增加“货位可用数量”字段,根据表头的选择的货位自动带出数值

    系统控制台——业务单据定制——货位间商品移库单(一步) 明细字段——增加“可销数量”字段. 然后修改明细字段的“商品编号”自定义查询方案. 增加自定义资料检索方案hwyksp SQL: select ...

  6. PHP实现打印出库单,有没有实现过?

    https://mp.weixin.qq.com/s/X3JldplICRq7KR0HNFcpuw 背景 有时候你在实现一个出库订单之类的功能模块,这里也有可能要你的站点也实现相应的打印出库单预览,今 ...

  7. SAP 出库单新版

    *&---------------------------------------------------------------------* *& Report  ZSDR045 ...

  8. ABAP 出库单打印 产品 A搭A A搭B显示方式

    *&---------------------------------------------------------------------* *& Report   *& ...

  9. SQL用先进先出存储过程求出库数量

    create table t( id ,), name ),--商品名称 j int, --入库数量 c int, --出库数量 jdate datetime --入库时间 ) ,,'2007-12- ...

随机推荐

  1. 节点文件将两个不同格式的XML文件,进行节点对照,并生成一个用于对照功能的XML

    本文纯属个人见解,是对前面学习的总结,如有描述不正确的地方还请高手指正~ 经常有的需求是,需要将一种格式的XML转换成另一种XML.如果要实现这个功能首先需要将两个不同XML手动建立节点对比关系.然后 ...

  2. C++ 内存相关

    1.C++的内存管理可分为以下几个部分: 栈:记录程序的执行过程. 堆:采用new,delete申请释放内存. 自由存储区:对应于C中使用malloc,free申请释放内存. 全局存储区:也叫静态存储 ...

  3. Codeforces Round #327 (Div. 2) E. Three States BFS

    E. Three States Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/591/probl ...

  4. Codeforces Gym 100523K K - Cross Spider 计算几何,判断是否n点共面

    K - Cross SpiderTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/v ...

  5. UVa 1252 - Twenty Questions(记忆化搜索,状态压缩dp)

    本文出自   http://blog.csdn.net/shuangde800 题目链接:点击打开链接 题目大意 有n个长度为m的二进制串,每个都是不同的. 为了把所有字符串区分开,你可以询问,每次可 ...

  6. Android之使用AchartEngineActivity引擎绘制柱状图、曲线图

    1.简介 AChartEngine(简称ACE)是Google的一个开源图表库(for Android).它功能强大,支持散点图.折线 .关于里面类的具体使用,请下载响应的文档说明(主页上有). 2. ...

  7. 一个坐标点围绕任意中心点旋转--C#实现

    假设对图片上任意点(x,y),绕一个坐标点(rx0,ry0)逆时针旋转RotaryAngle角度后的新的坐标设为(x', y'),有公式: x'= (x - rx0)*cos(RotaryAngle) ...

  8. Linux Bash命令关于程序调试详解

    转载:http://os.51cto.com/art/201006/207230.htm 参考:<Linux shell 脚本攻略>Page22-23 Linux bash程序在程序员的使 ...

  9. MYSQL基础笔记(一)

    关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...

  10. Recovery启动流程(2)---UI界面

    转载请注明来源:cuixiaolei的技术博客 Recovery启动流程系列文章把recvoery目录下文件分成小块讲解,最后再以一条主线贯穿所有的内容.这篇文章主要讲解Recovery-UI的相关内 ...