博客
关于我
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/

你可能感兴趣的文章
Nginx的是什么?干什么用的?
查看>>
Nginx访问控制_登陆权限的控制(http_auth_basic_module)
查看>>
nginx负载均衡器处理session共享的几种方法(转)
查看>>
nginx负载均衡的5种策略(转载)
查看>>
nginx负载均衡的五种算法
查看>>
Nginx运维与实战(二)-Https配置
查看>>
Nginx配置ssl实现https
查看>>
Nginx配置TCP代理指南
查看>>
Nginx配置——不记录指定文件类型日志
查看>>
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
Nginx配置参数中文说明
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
NHibernate学习[1]
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>