Project Icon

simple-exec

简化.NET外部命令执行的轻量级库

SimpleExec是一个用于简化.NET外部命令执行的开源库。它封装了System.Diagnostics.Process,提供简洁的API接口。支持同步和异步执行命令、读取输出,并具备灵活的错误处理机制。适用于.NET 6.0及以上版本,SimpleExec为开发者提供了高效的命令行操作解决方案。

SimpleExec

SimpleExec

NuGet版本

构建状态 CodeQL分析 代码检查 拼写检查

SimpleExec是一个用于运行外部命令的.NET库。它封装了System.Diagnostics.Process以简化使用。

SimpleExec有意不调用系统shell。

平台支持:.NET 6.0及更高版本

快速入门

using static SimpleExec.Command;
Run("foo", "arg1 arg2");

运行

Run("foo");
Run("foo", "arg1 arg2");
Run("foo", new[] { "arg1", "arg2" });

await RunAsync("foo");
await RunAsync("foo", "arg1 arg2");
await RunAsync("foo", new[] { "arg1", "arg2" });

默认情况下,命令会被回显到标准输出(stdout)以提高可见性。

读取

var (standardOutput1, standardError1) = await ReadAsync("foo");
var (standardOutput2, standardError2) = await ReadAsync("foo", "arg1 arg2");
var (standardOutput3, standardError3) = await ReadAsync("foo", new[] { "arg1", "arg2" });

其他可选参数

string workingDirectory = "",
bool noEcho = false,
string? echoPrefix = null,
Action<IDictionary<string, string?>>? configureEnvironment = null,
bool createNoWindow = false,
Encoding? encoding = null,
Func<int, bool>? handleExitCode = null,
string? standardInput = null,
bool cancellationIgnoresProcessTree = false,
CancellationToken cancellationToken = default,

异常

如果命令的退出代码非零,将抛出一个ExitCodeException异常,该异常包含一个int类型的ExitCode属性,以及以下形式的消息:

$"进程以代码{ExitCode}退出。"

对于ReadAsync,将抛出一个ExitCodeReadException异常,该异常继承自ExitCodeException,并具有string类型的OutError属性,分别表示标准输出(stdout)和标准错误(stderr),以及以下形式的消息:

$@"进程以代码{ExitCode}退出。

标准输出:

{Out}

标准错误:

{Error}"

覆盖默认退出代码处理

大多数程序在成功时返回零退出代码,失败时返回非零退出代码。然而,有些程序在成功时返回非零退出代码。例如,Robocopy在成功时返回小于8的退出代码,失败时返回大于等于8的退出代码。

可以通过向handleExitCode传递一个委托来抑制特定非零退出代码的异常抛出。当委托处理了退出代码并应抑制默认退出代码处理时,返回true;否则返回false

例如,在运行Robocopy时,应该为小于8的退出代码抑制异常抛出:

Run("ROBOCOPY", "from to", handleExitCode: code => code < 8);

请注意,记录退出代码可能很有用。例如:

var exitCode = 0;
Run("ROBOCOPY", "from to", handleExitCode: code => (exitCode = code) < 8);

// 参见 https://ss64.com/nt/robocopy-exit.html
var oneOrMoreFilesCopied = exitCode & 1;
var extraFilesOrDirectoriesDetected = exitCode & 2;
var misMatchedFilesOrDirectoriesDetected = exitCode & 4;

RunGregor Cresnar 提供,来自 the Noun Project

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号