整理期初数据用到的EXCEL里面的函数操作

项目上线切换阶段,上线策略之后确定后各模块需要做的工作,最重要的是期初数据的整理,会涉及待多个表的数据匹配关联等,包括物料与数量、物料与价格、物料与单位等

本人在PP模块期初切换系统时用到的EXCEL里面的函数如下:

  • 旧系统的在制工单数据在导入前需要检验新系统中的物料是否存在marc表中,以及检查生产物料的BOM、工艺路线、生产版本是否存在,就会用到:

    =IF(ISERROR(MATCH(A2,B:B,0)),A2,"")

    MATCH(A2, B:B, 0):在B列中查找A2单元格的值,如果找到,返回其在B列中的位置;如果未找到,返回错误。
    ISERROR(...):检查MATCH函数是否返回错误,如果返回错误(即A2中的物料不在B列中),则ISERROR返回TRUE。
    IF(..., A2, ""):如果ISERROR返回TRUE(即物料不在B列中),则将A2的值放入C列;否则,放入空字符串(即C列不显示任何内容)。

上面的方法会把不存在的值显示出来,也可以仅仅判断存不存在,可以用:

复制代码
=COUNTIF(A:A, B1)

如果结果大于0,表示B列的编码在A列中存在;如果结果为0,则表示不存在。

或者返回"存在"或"不存在",直观显示匹配结果:

复制代码
=IF(ISNA(VLOOKUP(B1, A:A, 1, FALSE)), "不存在", "存在")
  • 有新旧单位不匹配的情况,需要批量替换或者直接拿底表中的单位匹配,就会用到:

    =IFERROR(VLOOKUP(C2, A:B, 2, FALSE), "")

    VLOOKUP(C2, A:B, 2, FALSE):在 A 列中查找 C2 的值,如果找到,返回同一行 B 列的值。
    IFERROR(..., ""):如果找不到(即 C2 不在 A 列中),返回空字符串,而不是错误值。

同样匹配数量也可以用VLOOKUP;还可以用使用 INDEX + MATCH 函数:

复制代码
=IFERROR(INDEX(B:B, MATCH(C2, A:A, 0)), "")

MATCH(C2, A:A, 0):返回 C2 在 A 列中第一次出现的位置(行号)。
INDEX(B:B, ...):根据行号返回 B 列中对应的值。
IFERROR(..., ""):处理找不到的情况,返回空字符串。

更灵活实现"列A物料匹配列B物料后,将列C的单位对应到列A物料"的需求:

复制代码
=XLOOKUP(I2,M:M,O:O,"未找到")

注意:如果 A 列中有多个相同的物料,VLOOKUP 和 MATCH 都只会返回第一个匹配到的数量。

补充:

在数据表格式不确定的时候,直接的列总和和分类汇总数据会不准确(测试时候发现格式会影响计算结果),这时候就需要用到数据透视表,这个数据就是不会考虑到格式的差异,得到的结果是准确的。

此外,期初数据导入的准确性非常非常重要,一定要细心!!!!

相关推荐
weixin_462446238 小时前
【原创实践】python 获取节假日列表 并保存为excel
数据库·python·excel
缺点内向20 小时前
如何在C#中添加Excel文档属性?
开发语言·数据库·c#·.net·excel
shouchaobao20 小时前
仓库房进销存Excel模板合集:商品采购+出入库+库存统计一站式管理,适配仓库管理员/中小企业/个体商户
excel
chenhdowue21 小时前
如何使用 vxe-table 导出为带图片的单元格到 excel 格式文件
vue.js·excel·vxe-table·vxe-ui
码上成长1 天前
从零实现:react&Ts--批量导入 & Excel 模版下载功能
javascript·react.js·excel
heartbeat..1 天前
如何用 Excel / Java 去解决Excel下拉列表选项数量限制的问题(兼容.xsl和.xlsx)
java·开发语言·excel·poi
前端sweetGirl1 天前
Excel 里 XLOOKUP 函数返回日期时找不到值显示 1/0,怎么让他不显示
excel
EasyStudios1 天前
金色传说:SAP-ABAP-Excel数据导入工具函数示例
sap·abap·excel导入
来鸟 鸣间2 天前
excel快速填充
excel
葡萄城技术团队2 天前
Excel 文件到底是怎么坏掉的?深入 OOXML 底层原理讲解修复策略
android·java·excel