1、背景
使用CPLEX求解优化问题时,结果如果没有记录完整就运行其他算例的话,可能会导致时间浪费,所以及时保存结果非常重要!本文研究了一下CPLEX官网关于CPLEX和EXCEL对接的方法,在此记录一下,有需要的小伙伴自取呀。
2、CPLEX和EXCEL对接示例
下述时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");
相信好多小伙伴看完例子之后已经知道怎么导入导出了,本人就在这里提出几个小tips,帮助大家快速实现功能。
1、要注意上述内容需要在.dat文件中书写
2、sheet时之后需要用到的ID号,可以自己定义
3、'oil data'这些东西是Excel中的表的名称
4、!A2:A4这个是表的范围,关于这个范围,最好是能确定出准确的范围,如果确定不了,则指定的范围可以大一些(官方说指定大了或者小了都会报错,但是本人试验发现,指定大了之后不会报错哦)
4、a和blend是要输出的变量名,这里需要注意,变量的维度不能超过2… …其实这个限制让这个功能变得很鸡肋
3、多维变量保存方法
由于这个SheetWrite
功能只能限制到2维以下的数组输出,所以对于3维以上的变量数组输出可以祭出终极大招-复制粘贴… …博主暂时没找到合适的处理方式,有大神知道的话,恳请指点【抱拳了】。
4、绝对路径和相对路径
大家的文件路径可以使用绝对路径,语句如下所示:
SheetConnection sheetData("C:\\ILOG_Files\\myExcelFile.xls"); prods to SheetWrite(sheetData,"Product!A1:D100"); //prods是变量名
当然也可以使用相对路径,但是使用相对路径时,Excel文件需要和cplex工程的mod和dat文件放在同一个目录下,语句如下所示:
SheetConnection sheetData("myExcelFile.xls"); prods to SheetWrite(sheetData,"Product!A1:D100"); //prods是变量名
还有不明白的小伙伴可以参阅官方文档哦:
https://www.ibm.com/docs/zh/icos/20.1.0?topic=sources-spreadsheet-inputoutput