将跟踪输出重定向到控制台


74

假设我正在使用VB.Net中的一个小的批处理控制台应用程序。我希望能够像这样构建应用程序:

Sub WorkerMethod()
   'Do some work
   Trace.WriteLine("Work progress")

   'Do more work
   Trace.WriteLine("Another progress update")

   '...
End Sub


Sub Main()

   'Do any setup, like confirm the user wants to continue or whatever

   WorkerMethod()     

End Sub

请注意,我使用Trace而不是Console输出。这是因为worker方法可能是从其他地方调用的,甚至可能位于其他程序集中,并且我希望能够将不同的跟踪侦听器附加到该方法。那么如何将控制台连接到跟踪?

我已经可以通过定义一个简单的类(如下所示)并将一个实例添加到Trace的listeners集合中来做到这一点,但是我想知道是否还有一种更被接受或内置的方式来实现此目的:

Public Class ConsoleTrace
    Inherits Diagnostics.TraceListener

    Public Overloads Overrides Sub Write(ByVal message As String)
        Console.Write(message)
    End Sub

    Public Overloads Overrides Sub WriteLine(ByVal message As String)
        Console.WriteLine(message)
    End Sub
End Class

Answers:


157

您可以将以下内容添加到exe的.config文件中。

<?xml version="1.0"?>
<configuration>
    <system.diagnostics>
        <trace autoflush="true">
            <listeners>
                <add name="logListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="cat.log" />
                <add name="consoleListener" type="System.Diagnostics.ConsoleTraceListener"/>
            </listeners>
        </trace>
    </system.diagnostics>
</configuration>

如果您有兴趣登录到文件,我还包括了TextWriter。


2
赞成将我指向System.Diagnostics.ConsoleTraceListner。我以某种方式错过了。否则我没有app.config,但是我可以很轻松地在代码中进行设置。
Joel Coehoorn

1
这对于具有配置的.exe来说效果很好,但是我也有类似的情况,但带有DLL。我不想修改调用exe的.config文件(它是nunit-console.exe)。我会继续寻找,但是无论如何,我肯定学到了一些东西,就把你投了赞成票。
Scott Marlowe,2009年

55

乔尔

您可以这样做,而不是使用app config方法:

Trace.Listeners.Add(new ConsoleTraceListener());

或者,如果您想在应用程序的生命周期内管理添加或删除侦听器,请执行以下操作:

ConsoleTraceListener listener = new ConsoleTraceListener();
Trace.Listeners.Add(listener);

Trace.WriteLine("Howdy");

Trace.Listeners.Remove(listener);

Trace.Close();

11

很好的解决方案,但是我遇到的情况是我的同一个调用exe正在运行不同的dll,因此我不想修改调用exe的.config文件。我希望每个dll处理它自己的跟踪输出更改。

很简单:

Stream outResultsFile = File.Create ("output.txt");
var textListener = new TextWriterTraceListener (outResultsFile);
Trace.Listeners.Add (textListener);

当然,这会将输出Trace输出输出到“ output.txt”文件。


我知道这是旧帖子。但是我对此有疑问。您能否看一下我的文章:stackoverflow.com/questions/5568630/…。我在做同样的事情,但是使用了Debug,但没有任何结果,即输出文件为空。有任何想法吗?
TheBoyan 2011年
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.