提取 Excel 指定单元格数据

本文介绍了如何使用SPL语言提取Excel中指定单元格的数据,分为单元格名称固定和按条件查找两种情况。通过实例展示了如何直接读取单元格、按数据表格读取,以及如何在循环中按条件查找并提取数据。
部署运行你感兴趣的模型镜像

1. 思路

提取指定单元格数据,分以下两种情况:

1、 单元格名称固定不变。此时可以用xlscell函数直接按单元格名称读取,如果整个数据区是个数据表格,也可以用T函数读取序表后,再按记录行号和列名读取。

2、 单元格不固定,是按照某种条件查找到目标单元格。把Excel文件打开成SPL中的Excel对象,循环每行每列的单元格,读取单元格数据,按条件检查是否是目标单元格。

2. 举例

2.1 单元格名称固定

文件book1.xlsx中有如下图所示数据,现在想要提取B4和C4单元格数据。

1、已经知道要取数的单元格名称,可以直接读取,编写SPL脚本:

A
1=file("E:/work/book1.xlsx”).xlsopen()
2=A1.xlscell("B4",1)
3=A1.xlscell("C4")

A1 将文件book1.xlsx打开成Excel对象

A2 读取B4单元格的值,参数1是Sheet的序号,如果是第1个Sheet也可以省略此参数

A3 读取C4单元格的值

2、此文件中的数据是个数据表,也可以按序表读取,编写SPL脚本:

A
1=T("E:/work/book1.xlsx”)
2=A1(3).Quantity
3=A1(3).Amount

A1 将文件book1.xlsx打开成SPL中的序表

A2 取A1序表的第3行的Quantity列数据

A3 取A1序表的第3行的Amount列数据

2.2 按条件查找单元格

某企业有多张资产负债表,其中一张如下图所示:

现在需要从各表中提取Cash、Accounts receivable、Other receivables、Accounts payable 等4项的Endingbalance(期末余额)数据进行财务分析,在不同表中这4项的单元格位置可能不同,需要按项目名称去查找。

编写SPL脚本:

ABCD
1=create(Cash,'Accounts receivable','Other receivables','Accounts payable').insert(0)
2=file("E:/zcfzb/zcfzb1.xlsx").xlsopen()
3for A2.nrowsfor A2.ncols=trim(A2.xlscell(cellname(A3,B3)))
4if A1.fname().contain(C3)>A1(1).field(C3,A2.xlscell(cellname(A3,B3+2)))

A1 创建保存提取数据的序表,并插入一条新记录

A2 打开文件zcfzb1.xlsx为Excel对象

A3 循环文件每一行

B3 循环当前行的每一列

C3 读出当前单元格的内容并删除两端的空白,cellname函数将行列号转换成单元格名称

C4D4 判断当前单元格内容是否是A1序表的列名,若是则读取它右边第2个单元格内容,并保存在A1中第1条记录的对应列中

您可能感兴趣的与本文相关的镜像

Dify

Dify

AI应用
Agent编排

Dify 是一款开源的大语言模型(LLM)应用开发平台,它结合了 后端即服务(Backend as a Service) 和LLMOps 的理念,让开发者能快速、高效地构建和部署生产级的生成式AI应用。 它提供了包含模型兼容支持、Prompt 编排界面、RAG 引擎、Agent 框架、工作流编排等核心技术栈,并且提供了易用的界面和API,让技术和非技术人员都能参与到AI应用的开发过程中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值