ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 548|回复: 0

使用关联表做区间关联

[复制链接]

TA的精华主题

TA的得分主题

发表于 2022-6-8 09:39 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
例1
Excel文件book1.xlsx中,部分数据如下所示:
另一个文件book2.xlsx中有数量区间与价格的对应关系表,如下图所示:
现在要计算book1.xlsx中B列的价格值,计算规则是用数量Quantity在book2.xlsx中查找,若数量大于Quantity1且小于等于Quantity2,则返回此行的价格。
编写SPL脚本:
A
1=T("e:/work/book1.xlsx")
2=T("e:/work/book2.xlsx")
3=A1.run(Price=A2.segp@r(Quantity1,A1.Quantity).Price)
4=T("e:/work/book1.xlsx",A1)
A1 读出book1.xlsx数据
A2 读出book2.xlsx数据
A3 循环A1每条记录,用segp函数查询Quantity的值位于A2的Quantity1构成的区间的哪个段号,再从A2中取出对应号的记录的价格赋给Price。选项@r表示形成左开右闭的区间,比如数量50应该算成是第1行所在的区间。
A4 把A1中的结果保存到文件book1.xlsx
例2
Excel文件book1.xlsx中有汽车充电数据,部分数据如下所示:
另一个文件book2.xlsx中有充电时段对应的电价,如下图所示:
现在要计算book1.xlsx中Price列的价格,计算规则是用充电开始时间Starttime的小时数在book2.xlsx中查找所处时段的价格。
编写SPL脚本:
A
1=T("e:/work/book1.xlsx")
2=file("e:/work/book2.xlsx").xlsimport@w()
3=A1.run(Price=A2(3).to(2,)(A2(1).to(2,).pseg(hour(A1.Starttime))))
4=T("e:/work/book1.xlsx",A1)
A1 读出book1.xlsx数据
A2 读出book2.xlsx数据,选项@w表示读成序列的序列
A3 循环A1每条记录,用A2中第1行第2列开始的Starthour序列形成区间,在此区间查找A1.Starttime中的小时所处的分段号,从A2第3行的Price中取出对应分段号的价格赋给Price。
A4 把A1中的结果保存到文件book1.xlsx

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-21 23:47 , Processed in 0.037921 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表