CPLEX导出数据到EXCEL

本文介绍了如何使用CPLEX解决优化问题时与Excel进行数据交互,包括从Excel导入数据、导出结果,并提供了一些实用提示。例如,通过SheetRead和SheetWrite函数读写Excel数据,注意变量维度限制。对于多维变量的保存,建议使用复制粘贴方法。同时,文章提到了使用绝对路径和相对路径来指定Excel文件的位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、背景

\qquad 使用CPLEX求解优化问题时,结果如果没有记录完整就运行其他算例的话,可能会导致时间浪费,所以及时保存结果非常重要!本文研究了一下CPLEX官网关于CPLEX和EXCEL对接的方法,在此记录一下,有需要的小伙伴自取呀。

2、CPLEX和EXCEL对接示例

\qquad 下述时CPLEXoil示例中导入Excel数据和导出Excel数据的例子。

prepare {
  writeln("* Note: This OPL data file is not compliant with cloud execution");
}
SheetConnection sheet("oilSheet.xls");
Gasolines from SheetRead(sheet,"'gas data'!A2:A4");
Oils from SheetRead(sheet,"'oil data'!A2:A4");
Gas from SheetRead(sheet,"'gas data'!B2:E4");
Oil from SheetRead(sheet,"'oil data'!B2:E4");
MaxProduction = 14000;
ProdCost = 4;


a to SheetWrite(sheet,"RESULT!A2:A4");
Blend to SheetWrite(sheet,"RESULT!B2:D4");

\qquad 相信好多小伙伴看完例子之后已经知道怎么导入导出了,本人就在这里提出几个小tips,帮助大家快速实现功能。
\qquad 1、要注意上述内容需要在.dat文件中书写
\qquad 2、sheet时之后需要用到的ID号,可以自己定义
\qquad 3、'oil data'这些东西是Excel中的表的名称
\qquad 4、!A2:A4这个是表的范围,关于这个范围,最好是能确定出准确的范围,如果确定不了,则指定的范围可以大一些(官方说指定大了或者小了都会报错,但是本人试验发现,指定大了之后不会报错哦)
\qquad 4、ablend是要输出的变量名,这里需要注意,变量的维度不能超过2… …其实这个限制让这个功能变得很鸡肋

3、多维变量保存方法

\qquad 由于这个SheetWrite功能只能限制到2维以下的数组输出,所以对于3维以上的变量数组输出可以祭出终极大招-复制粘贴… …博主暂时没找到合适的处理方式,有大神知道的话,恳请指点【抱拳了】。

4、绝对路径和相对路径

\qquad 大家的文件路径可以使用绝对路径,语句如下所示:

SheetConnection sheetData("C:\\ILOG_Files\\myExcelFile.xls");
prods to SheetWrite(sheetData,"Product!A1:D100"); //prods是变量名

\qquad 当然也可以使用相对路径,但是使用相对路径时,Excel文件需要和cplex工程的mod和dat文件放在同一个目录下,语句如下所示:

SheetConnection sheetData("myExcelFile.xls");
prods to SheetWrite(sheetData,"Product!A1:D100"); //prods是变量名

在这里插入图片描述
\qquad 还有不明白的小伙伴可以参阅官方文档哦:
https://www.ibm.com/docs/zh/icos/20.1.0?topic=sources-spreadsheet-inputoutput

THE END

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dragon Fly

多谢老板赏钱[抱拳抱拳抱拳]

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值