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();
}
算法需求
(2)订单数<库存数总和 则 适配数 = 任意库位的数量的分配(必须=订单数)
(3)库存量大的库位优先适配;同等数量的库位,库位编号小的优先适配策略
PDA库位商品出库适配算法的更多相关文章
- ERP库位分布看板(库位管理)
客户正在使用的看板管理,根据厂家需求,做的二次开发. 一:看板效果 二:客户需求 1.客户需求:XX是一家汽车零部件(胶管,硅胶管等)的生产厂家,因此对原料,半成品的有效期有严格的要求. 多次调研得知 ...
- 127_Power Pivot&Power BI DAX计算订单商品在库时间(延伸订单仓储费用)
博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 前面已经写过一个先进先出的库龄案例,在业务发生又有这样一个需求:先进先出前提,需要按照订单计算每个商品在库时间, ...
- 关于推荐库位 java前端与SQL语句后面的结合
----------------------------------------------------------------------------------- select a1.id,a1. ...
- k3 cloud成本调整单提示期末余额不存在调整单分录的维度,请先出库核算确认是否存在核算维度的数据
成本调整单提示期末余额不存在调整单分录的维度,请先出库核算确认是否存在核算维度的数据,如下图所示: 解决办法:先做出库核算,然后做成本调整单,再做出库核算(出库成本核算)
- 用友CDM系统“货位间商品移库单(一步)”表体增加“货位可用数量”字段,根据表头的选择的货位自动带出数值
系统控制台——业务单据定制——货位间商品移库单(一步) 明细字段——增加“可销数量”字段. 然后修改明细字段的“商品编号”自定义查询方案. 增加自定义资料检索方案hwyksp SQL: select ...
- PHP实现打印出库单,有没有实现过?
https://mp.weixin.qq.com/s/X3JldplICRq7KR0HNFcpuw 背景 有时候你在实现一个出库订单之类的功能模块,这里也有可能要你的站点也实现相应的打印出库单预览,今 ...
- SAP 出库单新版
*&---------------------------------------------------------------------* *& Report ZSDR045 ...
- ABAP 出库单打印 产品 A搭A A搭B显示方式
*&---------------------------------------------------------------------* *& Report *& ...
- SQL用先进先出存储过程求出库数量
create table t( id ,), name ),--商品名称 j int, --入库数量 c int, --出库数量 jdate datetime --入库时间 ) ,,'2007-12- ...
随机推荐
- 80端口被NT kernel & System 占用pid 4
前段时间停止了Apache,结果在打开的时候发现无法打开,80端口被占用,于是win+r 运行cmd 输入netstat -ano 可以看到80端口被PID4占用,于是打开任务管理器-进程-查看,选择 ...
- 详谈 php定时器
以前对se特别感兴趣,但是自己又不会java,lucene等搜索引擎开发工具,于是不断挖掘php的功效. 最后发现php也可以做抓取,并且原理很易:直接获取页面源文件,然后通过正则或字符串的参照截取来 ...
- linux 进程地址空间的一步步探究
我们知道,在32位机器上linux操作系统中的进程的地址空间大小是4G,其中0-3G是用户空间,3G-4G是内核空间.其实,这个4G的地址空间是不存在的,也就是我们所说的虚拟内存空间. 那虚拟内存空间 ...
- 高级I/O之异步I/O
A synchronous I/O operation causes the requesting process to be blocked until that I/O operation com ...
- Lua调用自定义C++类
弄了一天终于会Lua调用自定义C++类.不容易啊. 我的电脑是64位的,装了64的Python不行,装了32位的就可以了,靠!下面是报错信息 python pyyaml Cheetah全都是装32位的 ...
- Python拼接多张图片
写机器学习相关博文,经常会碰到很多公式,而Latex正式编辑公式的利器.目前国内常用的博客系统,好像只有博客园支持,所以当初选择落户博客园.我现在基本都是用Latex写博文,然后要发表到博客园上与大家 ...
- 从 Auto Layout 的布局算法谈性能
这是使用 ASDK 性能调优系列的第二篇文章,前一篇文章中讲到了如何提升 iOS 应用的渲染性能,你可以点击 这里 了解这部分的内容. http://t.cn/Rc4KbUC 在上一篇文章中,我们提到 ...
- Web Navigation
Description Standard web browsers contain features to move backward and forward among the pages rece ...
- Android(java)学习笔记77:网络编程的概述
计算机网络 是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统. 网络编程 就 ...
- 防止vuejs在解析时出现闪烁
---## 防止vuejs在解析时出现闪烁 ## 原因: 在使用vuejs.angularjs开发时,经常会遇见在如Chrome这类能够快速解析的浏览器上出现表达式({{ express }} ),或 ...