博客
关于我
C#执行EXE文件与输出消息的提取
阅读量:339 次
发布时间:2019-03-04

本文共 1111 字,大约阅读时间需要 3 分钟。

在C# WPF环境下调用命令行程序,本文将详细说明如何通过Process类实现进程管理和参数传递。

1. Process类实例声明

首先,我们声明并初始化一个Process类实例:

Process p = new Process();

2. 设置进程参数

接下来,配置进程的启动信息,确保输入输出重定向:

p.StartInfo.CreateNoWindow = true;    // 不创建新窗口p.StartInfo.UseShellExecute = false;  // 禁用Shell启动方式p.StartInfo.RedirectStandardInput = true; // 重定向标准输入p.StartInfo.RedirectStandardOutput = true; // 重定向标准输出p.StartInfo.RedirectStandardError = true; // 重定向错误输出p.StartInfo.FileName = "cmd.exe"; // 指定使用cmd.exe

3. 启动进程

调用Start方法启动进程:

p.Start();

4. 模拟输入

通过标准输入管道向cmd.exe传递指令和参数:

string command = "avrdude -C avrdude -v -p atmega32u4 -c avr109 -P " + portName + " -b 57600 -D -U flash:w:node.hex:i";p.StandardInput.WriteLine(command + " & exit");p.StandardInput.AutoFlush = true; // 确保输入及时处理p.StandardInput.Close(); // 关闭输入管道

5. 获取输出

读取进程的标准输出和错误信息:

string output = p.StandardOutput.ReadToEnd();string error = p.StandardError.ReadToEnd();p.WaitForExit(1000); // 等待进程最大1000ms后退出,防止超时p.Close(); // 关闭进程

注意事项

  • 确保在调用Process类前注册mscorlib namespace:using System.Diagnostics;
  • 如果需要处理进程输出,可参考WaitForExit方法或事件手册
  • 建议在实际应用中根据需要调整等待时间,避免死锁

通过以上步骤,可以在C# WPF项目中安全地调用命令行程序,并灵活管理进程输入输出。

转载地址:http://xqyh.baihongyu.com/

你可能感兴趣的文章
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>