没有输出到WPF应用程序的控制台?

我从一个非常简单的WPFtesting应用程序使用Console.WriteLine(),但是当我从命令行执行应用程序时,我看不到任何东西被写入控制台。 有人知道这里可能会发生什么吗?

我可以通过在VS 2008中创build一个WPF应用程序来重现它,并在任何执行的地方添加Console.WriteLine(“text”)。 有任何想法吗?

我现在需要的只是Console.WriteLine()这样简单的东西。 我意识到我可以使用log4net或其他日志logging解决scheme,但我真的不需要这个应用程序的多lessfunction。

编辑:我应该记住,Console.WriteLine()是为控制台应用程序。 哦,没有愚蠢的问题,对不对? :-)我现在只使用System.Diagnostics.Trace.WriteLine()和DebugView。

在实际调用任何Console.Write方法之前,您必须手动创build一个控制台窗口。 这将启动控制台正常工作,而无需更改项目types(WPF应用程序将无法工作)。

下面是完整的源代码示例,ConsoleManager类的外观如何,以及如何使用它来启用/禁用控制台,而与项目types无关。

使用以下类,您只需要在Console.Write任何调用之前编写ConsoleManager.Show()

 [SuppressUnmanagedCodeSecurity] public static class ConsoleManager { private const string Kernel32_DllName = "kernel32.dll"; [DllImport(Kernel32_DllName)] private static extern bool AllocConsole(); [DllImport(Kernel32_DllName)] private static extern bool FreeConsole(); [DllImport(Kernel32_DllName)] private static extern IntPtr GetConsoleWindow(); [DllImport(Kernel32_DllName)] private static extern int GetConsoleOutputCP(); public static bool HasConsole { get { return GetConsoleWindow() != IntPtr.Zero; } } /// <summary> /// Creates a new console instance if the process is not attached to a console already. /// </summary> public static void Show() { //#if DEBUG if (!HasConsole) { AllocConsole(); InvalidateOutAndError(); } //#endif } /// <summary> /// If the process has a console attached to it, it will be detached and no longer visible. Writing to the System.Console is still possible, but no output will be shown. /// </summary> public static void Hide() { //#if DEBUG if (HasConsole) { SetOutAndErrorNull(); FreeConsole(); } //#endif } public static void Toggle() { if (HasConsole) { Hide(); } else { Show(); } } static void InvalidateOutAndError() { Type type = typeof(System.Console); System.Reflection.FieldInfo _out = type.GetField("_out", System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic); System.Reflection.FieldInfo _error = type.GetField("_error", System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic); System.Reflection.MethodInfo _InitializeStdOutError = type.GetMethod("InitializeStdOutError", System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic); Debug.Assert(_out != null); Debug.Assert(_error != null); Debug.Assert(_InitializeStdOutError != null); _out.SetValue(null, null); _error.SetValue(null, null); _InitializeStdOutError.Invoke(null, new object[] { true }); } static void SetOutAndErrorNull() { Console.SetOut(TextWriter.Null); Console.SetError(TextWriter.Null); } } 

右键单击项目“属性”,“应用程序”选项卡,将“输出types”更改为“控制台应用程序”,然后它也将有一个控制台。

您可以使用

 Trace.WriteLine("text"); 

这将输出到Visual Studio中的“输出”窗口(debugging时)。

确保包含诊断程序集:

 using System.Diagnostics; 

尽pipe约翰·莱德格伦(John Leidegren)一直在打击这个想法,但布赖恩是正确的 我刚刚在Visual Studio中工作。

要清除WPF应用程序默认情况下不会创build控制台窗口。

您必须创build一个WPF应用程序,然后将OutputType更改为“控制台应用程序”。 当你运行这个项目时,你会看到一个控制台窗口,在你的WPF窗口前面。

它看起来不是很漂亮,但是我发现它很有帮助,因为我希望我的应用程序能够从命令行运行,并在那里提供反馈,然后对于某些命令选项,我将显示WPF窗口。

可以通过使用命令行redirect来查看用于控制台的输出。

例如:

 C:\src\bin\Debug\Example.exe > output.txt 

将所有内容写入output.txt文件。

旧的post,但我碰到这个,所以如果你想在Visual Studio中的WPF项目输出的东西输出,当代的方法是:

包括:

 using System.Diagnostics; 

接着:

 Debug.WriteLine("something"); 

我使用Console.WriteLine()在输出窗口中使用…

看看这个post,对我自己很有帮助。 下载代码示例:

http://www.codeproject.com/Articles/335909/Embedding-a-Console-in-aC-Application

据我所知,Console.WriteLine()仅用于控制台应用程序。 我认为这是你的问题。