Ошибка запуска исполняемого файла из подпроцесса Python
Я пытаюсь запустить исполняемый файл (решатель линейного программирования CLP.exe) из Python 3.5.
Import subprocess
exeFile = " C:\\MyPath\\CLP.exe"
arg1 = "C:\\Temp\\LpModel.mps"
arg2 = "-max"
arg3 = " -dualSimplex"
arg4 = " -printi all"
arg5 = "-solution t solutionFile.txt"
subprocess.check_output([exeFile, arg1, arg2, arg3, arg4, arg5], stderr=subprocess.STDOUT, shell=False)
Когда я запускаю файл python в Eclipse PyDev, я вижу результаты в консоли Eclipse.
Но результаты решения не сохраняются в файле "solutionFile.txt".
В консоли Eclipse я получил:
b'Coin LP version 1.16, build Dec 25 2015
command line - C:\\MyPath\\clp.exe C:\\Temp\\LpModel.mps -max -dualSimplex -printi all -solution C:\\Temp\\solution.txt
At line 1 NAME ClpDefau
At line 2 ROWS
At line 5 COLUMNS
At line 8 RHS
At line 10 BOUNDS
At line 13 ENDATA
Problem ClpDefau has 1 rows, 2 columns and 2 elements
Model was imported from C:\\Temp\\LpModel.mps in 0.001 seconds
No match for -max - ? for list of commands
No match for -dualSimplex - ? for list of commands
No match for -printi all - ? for list of commands
No match for -solution C:\\Temp\\solution.txt - ? for list of commands
Presolve 0 (-1) rows, 0 (-2) columns and 0 (-2) elements
Empty problem - 0 rows, 0 columns and 0 elements
Optimal - objective value 4
After Postsolve, objective 4, infeasibilities - dual 0 (0), primal 0 (0)
Optimal objective 4 - 0 iterations time 0.002, Presolve 0.00
Когда я запускаю команду в оболочке MS Windows из командной строки:
C:\\MyPath\\clp.exe C:\\Temp\\LpModel.mps -max -dualSimplex -printi all -solution C:\\Temp\\solution.txt
Я могу получить результаты в файле решения. И жирные линии не появляются в выводе, если я запускаю команду в командной строке.
Почему файл solition.txt не был создан и в него не были сохранены результаты решений, если я запускаю команду из подпроцесса Python?
1 ответ
Решение
Каждый разделенный пробелами токен должен быть другим аргументом в массиве для subprocess.check_output
exeFile = " C:\\MyPath\\CLP.exe"
subprocess.check_output([
exeFile,
"C:\\Temp\\LpModel.mps",
"-max",
"-dualSimplex",
"-printi",
"all",
"-solution",
"t",
"solutionFile.txt"],
stderr=subprocess.STDOUT,
shell=False)