我正在从 C# 调用 Gurobi(多次)。因此,控制台输出是我的和 Gurobi 日志记录的混合。如果我覆盖 Console.Out,则只有我的输出被重定向,但 Gurobi(显然包装了非托管 dll)仍然写入屏幕。
有什么方法可以从控制台获取每一行(作为字符串或文件)?
最佳答案
您可以使用回调对象捕获 Gurobi 的控制台输出。回调对象有一个 Callback()
方法,调用该方法的原因有很多,其中之一是告诉您它将要写入控制台的文本。您可以对这段文字做任何您想做的事情。在下面的示例中,我将文本编写为调试输出:
class MyGRBCallback : GRBCallback
{
protected override void Callback()
{
if (this.where == GRB.Callback.MESSAGE)
{
String text = this.GetStringInfo(GRB.Callback.MSG_STRING);
Debug.WriteLine(text);
}
}
}
您可以使用 GRBModel 的 SetCallback
方法告诉 Gurobi 您的回调对象。
var env = new GRBEnv();
var m = new GRBModel(env);
var callback = new MyGRBCallback();
m.SetCallback(callback);
Gurobi 此时将调用您的回调并写入控制台。您可以告诉 Gurobi 不要写入控制台:
env.Set(GRB.IntParam.LogToConsole, 0);
关于c# - 不使用 SetOut 控制台输出到文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28982082/