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、a
和blend
是要输出的变量名,这里需要注意,变量的维度不能超过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