Получение динамического вывода командной строки
Я запускаю программу, используя командную строку в С#, эта программа создает несколько журналов, в то время как ее запуск должен отображать эти журналы всякий раз, когда они меняются. Я написал следующий код, но он показывает все журналы после того, как процесс был убит, а во время работы моя программа не отвечает. как я могу это исправить?
рассматривает
ProcessStartInfo procStartInfo = new System.Diagnostics.ProcessStartInfo("cmd", "/c " + "C:\\server.py");
Process proc = new Process();
procStartInfo.WindowStyle = ProcessWindowStyle.Hidden;
procStartInfo.UseShellExecute = false;
procStartInfo.RedirectStandardOutput = true;
//procStartInfo.CreateNoWindow = true;
proc.StartInfo = procStartInfo;
proc.Start();
string output = proc.StandardOutput.ReadToEnd();
proc.WaitForExit(300);
LogstextBox.Text = output;
Отредактировано:
ну, я пытался использовать OutputDataReceived
, но он не показывает никакого результата, вот измененный код:
{
//processCaller.FileName = @"ping";
//processCaller.Arguments = "4.2.2.4 -t"; this is working
processCaller.FileName = @"cmd.exe";
processCaller.Arguments = "/c c:\\server.py"; //this is not working
processCaller.StdErrReceived += new DataReceivedHandler(writeStreamInfo);
processCaller.StdOutReceived += new DataReceivedHandler(writeStreamInfo);
processCaller.Completed += new EventHandler(processCompletedOrCanceled);
processCaller.Cancelled += new EventHandler(processCompletedOrCanceled);
this.richTextBox1.Text = "Server Started.." + Environment.NewLine;
processCaller.Start();
}
private void writeStreamInfo(object sender, DataReceivedEventArgs e)
{
this.richTextBox1.AppendText(e.Text + Environment.NewLine);
}
Ответы
Ответ 1
В этом проблема:
string output = proc.StandardOutput.ReadToEnd();
Вы не достигнете "конца" стандартного вывода до тех пор, пока процесс не завершится.
Вы должны читать строку за раз - или, возможно, просто подписываться на OutputDataReceived
событие (и следуя документированным другим требованиям для этого события).
EDIT: Здесь пример кода, который работает для меня:
using System;
using System.Diagnostics;
using System.Threading;
class Program
{
public static void Main()
{
ProcessStartInfo startInfo = new ProcessStartInfo("cmd", "/c " + "type Test.cs")
{
WindowStyle = ProcessWindowStyle.Hidden,
UseShellExecute = false,
RedirectStandardOutput = true,
CreateNoWindow = true
};
Process process = Process.Start(startInfo);
process.OutputDataReceived += (sender, e) => Console.WriteLine(e.Data);
process.BeginOutputReadLine();
process.WaitForExit();
// We may not have received all the events yet!
Thread.Sleep(5000);
}
}
Обратите внимание, что в вашем примере кода вы получаете доступ к пользовательскому интерфейсу в любом потоке, который вызывается обработчиком OutputDataReceived
, - это выглядит плохой идеей для меня.
Ответ 2
Вы можете использовать Process.BeginOutputReadLine Method. Ссылка показывает полный рабочий пример в С#, который использует OutputDataReceived event
. Этот пример кода должен делать то, что вы хотите.