C# 使用ProcessStartInfo调用exe获取不到重定向数据的解决方案
emmmmm,最近在研究WFDB工具箱,C语言写的,无奈本人C语言功底不够,只想直接拿来用,于是打算通过ProcessStartInfo来调取编译出来的exe程序获取输出。
一开始就打算偷懒,从园子里的前辈blog上偷来部分代码,和着自己写的代码差不多就写了以下调取程序的代码:
1 /// <summary> 2 /// 调用Exe核心代码 3 /// </summary> 4 /// <param name="exeFileName"></param> 5 /// <param name="args"></param> 6 public void RunExe(string exeFileName, string args = "") 7 { 8 try 9 { 10 11 Process p = new Process(); 12 13 p.StartInfo = new ProcessStartInfo(exeFileName, args); 14 15 p.StartInfo.Arguments = args; 16 //p.StartInfo.WorkingDirectory = @"C:\MinGW\msys\1.0\home\61125\wfdb-10.6.1\build\bin"; 17 p.StartInfo.UseShellExecute = false; 18 19 p.StartInfo.RedirectStandardOutput = true; 20 21 //p.StartInfo.RedirectStandardInput = true; 22 23 p.StartInfo.RedirectStandardError = true; 24 25 p.StartInfo.CreateNoWindow = false; 26 //绑定事件 27 p.OutputDataReceived += new DataReceivedEventHandler(p_OutputDataReceived); 28 p.ErrorDataReceived += P_ErrorDataReceived; 29 30 p.Start(); 31 p.BeginOutputReadLine();//开始读取输出数据 32 p.WaitForExit(); 33 p.Close(); 34 } 35 catch (Exception e) 36 { 37 Console.WriteLine(e); 38 throw; 39 } 40 }
然后使用时发现了问题,按照wfdb 中app的设计,直接调取exe是会弹出help内容的,可是我自己调用却不行。
无奈自己就搭建C环境,MinGw配合Visual Code配置了一把,踩了好多坑,才在windows环境下跑起了wfdb并能够调试。具体坑就不谈了。(有意愿的小伙伴可以和我沟通交流一下~)
研究了C代码发现异常输出都是通过
1 fprintf(stderr, "xxxxx")
此类形式输出的,搜索一下,查看了前辈的文章(https://www.cnblogs.com/tshua/p/5730658.html)发现输出流是有讲究的,不是全部通过Output通道发送的。
于是困扰了我两天的问题解决方案如下:
1 /// <summary> 2 /// 调用Exe核心代码 3 /// </summary> 4 /// <param name="exeFileName"></param> 5 /// <param name="args"></param> 6 public void RunExe(string exeFileName, string args = "") 7 { 8 try 9 { 10 11 Process p = new Process(); 12 13 p.StartInfo = new ProcessStartInfo(exeFileName, args); 14 15 p.StartInfo.Arguments = args; 16 //p.StartInfo.WorkingDirectory = @"C:\MinGW\msys\1.0\home\61125\wfdb-10.6.1\build\bin"; 17 p.StartInfo.UseShellExecute = false; 18 19 p.StartInfo.RedirectStandardOutput = true; 20 21 //p.StartInfo.RedirectStandardInput = true; 22 23 p.StartInfo.RedirectStandardError = true; 24 25 p.StartInfo.CreateNoWindow = false; 26 //绑定事件 27 p.OutputDataReceived += new DataReceivedEventHandler(p_OutputDataReceived); 28 p.ErrorDataReceived += P_ErrorDataReceived; 29 30 p.Start(); 31 p.BeginOutputReadLine();//开始读取输出数据 32 p.BeginErrorReadLine();//开始读取错误数据,重要! 33 p.WaitForExit(); 34 p.Close(); 35 } 36 catch (Exception e) 37 { 38 Console.WriteLine(e); 39 throw; 40 } 41 }
加入一行关键的
p.BeginErrorReadLine();//开始读取错误数据,重要!
就解决了问题。
emmmm。。(lll¬ω¬)
仅以此篇随笔防止其他小伙伴和我一样走弯路≡(▔﹏▔)≡