Dotnet Core 优雅的命令行实现

介绍一个命令行的实现库,可以优雅而简单的实现命令行应用。

前言

控制台应用 Console,在我们开发中用处很多。小到一个简单的功能测试,或一组不需要复杂 UI 的工具类应用,大到后端的服务,都会用到 Console。

在这里面,命令行应用 Cli,又是非常典型的一个应用类型。

命令行应用,通常概念上需要我们输入一定参数,根据参数的不同,选择不同的程序流程或方法来执行。

举个简单的例子:

% python3
Python 3.9.0 (default, Nov 13 2020, 12:12:14) 
[Clang 12.0.0 (clang-1200.0.32.21)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import OS
Traceback (most recent call last):File "<stdin>", line 1, in <module>
ModuleNotFoundError: No module named 'OS'
>>> import os
>>> print("Hello WangPlus")
Hello WangPlus
>>> exit()

不需要管 python3 是什么,这不重要。

我们能看到,当进入一个命令行时,一般首先会有简单的功能介绍,然后是一个提示符,在这里是 >>>。然后可以输入命令和参数,如果输入正确,会有错误提示。如果输入正确,会有适当的输出。

通常,如果想实现这样的效果,我们需要一个大的循环,来解析和响应输入的命令和参数,然后进行对应的处理。

事实上,在做这样一个应用时,会有很大的精力来处理这个循环。不相信的话,可以自己试着写一写。

今天给大家介绍的,是一个库,Nuget 上的库,也是我最近无意中发现的,但给了我很大的惊喜。事实上,我自己在写应用时,如果有可能,我会优先采用 Console 或 Cli 的方式来写,轻量、快速,不用处理太多 UI 方面的工作。

这个库叫 CommandLineTool。

下面进入正题,我从头介绍一下这个库的使用。

创建项目

先来创建项目。老习惯,用命令行创建:

% dotnet new console -o demo -f net5.0

这儿需要注意一下,这个库目前支持到 Dotnet Core 5.0,所以我们就用 5.0 了。

然后,引入 CommandLineTool:

% dotnet add package CommandLineTool

就这样,工程就算是建完了。

实现功能

这个库最简单的地方,是实现起来非常简单。

第一步,先建一个类

这个类,就是我们要实现 Cli 命令行功能的类 TestCLI:

[App("Demo")]
public class TestCLI
{
}

类是空的,先不管它。

第二步,在 Program.cs 里加入这个类

class Program
{static void Main(string[] args){Cli cli = new Cli(typeof(TestCLI)){Introduction = "这是一个 Demo 应用",PromptText = "WangPlus",};cli.SetCancellationKeys(new() { "exit" });cli.Start();}
}

看一个加入的内容:

Introduction - 这个 Cli 的说明,提示一下这个程序的功能,随便写;

PromptText - 这个是提示符的内容,类似于最上面例子的 >>>;

下面这一句cli.SetCancellationKeys(new() { "exit" });,是定义了退出的命令。也就是说,在提示符后输入 exit,应用就退出了。

跑一下这个应用:

% dotnet demo.dll
这是一个 Demo 应用WangPlus > ?
'?' was not matched. Did you mean '-h'?
Unrecognized command or argument '?'demoDemoUsage:demo [options]Options:--version       Show version information-?, -h, --help  Show help and usage informationWangPlus >exit
Terminating console...

哇哈哈,一个简单的 Cli 架子搭出来了。

第三步,开始写命令处理

命令处理放在 TestCLI.cs 中。

[App("Demo")]
public class TestCLI
{[Command("hello", "就是打个招呼")]public static void Hello([ParamArgument()] string name){Console.WriteLine($"Hello {name}");}
}

方法还是我们非常熟悉的一个普通方法,并没有什么特别的。

再跑一下:

WangPlus >hello
Required argument missing for command: hellohello就是打个招呼Usage:demo [options] hello <name>Arguments:<name>Options:-?, -h, --help  Show help and usage informationWangPlus >hello wang  
Hello wang

出来效果了。

重点看一下代码里的几个部分:

属性 Command,里面两个参数,第一个参数就是我们要实现的命令,第二个参数是命令的说明。

方法里,[ParamArgument()] 表示后面跟的参数来自于输入的命令的参数。

下面还有几种形式:

//多个参数
[Command("multiinput", "多个参数")]
public static void MultiInput([ParamArgument()] List<string> names) {}//多个文件
[Command("multifile", "多个文件")]
public static void MultiFile([ParamArgument()] List<FileInfo> files) {}//额外的参数
[Command("withpara", "额外参数")]
public static void WithPara([ParamArgument()] string names, [ParamOption("-a")] string op1) {}

重点说一下额外参数的方式。

有时候,我们可能需要下面的方式来处理命令:

% demo -a a-value -b b-value command

这个方式,就是来解决这样的问题的。

有没有 Get 到爽点?

本文有配套代码,在 https://github.com/humornif/Demo-Code/tree/master/0053/demo

喜欢就来个三连,让更多人因你而受益

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/300870.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android 获取当前画布,Android硬件位图填坑之获取硬件画布

前言Hardware Bitmap(硬件位图)是Android8.0加入的新功能&#xff0c;通过设置Bitmap的config为Bitmap.Config.HARDWARE&#xff0c;创建所谓的Hardware Bitmap&#xff0c;它不同与其他Config的Bitmap&#xff0c;Hardware Bitmap对应的像素数据是存储在显存中&#xff0c;并对…

JSP数据库连接方式总结

现在有好多初学jsp的网友经常会问数据库怎么连接啊&#xff0c;怎么老出错啊&#xff1f;所以我集中的在这写篇文章供大家参考&#xff0c;其实这种把数据库逻辑全部放在jsp里未必是好的做法&#xff0c;但是有利于初学者学习&#xff0c;所以我就这样做了&#xff0c;当大家学…

Java中Filter的理解

Filter工作原理当客户端发出Web资源的请求时&#xff0c;Web服务器根据应用程序配置文件设置的过滤规则进行检查&#xff0c;若客户请求满足过滤规则&#xff0c;则对客户请求&#xff0f;响应进行拦截&#xff0c;对请求头和请求数据进行检查或改动&#xff0c;并依次通过过滤…

一句话征服了美国人,这位饱受争议的数学博士竟从未上过学?

全世界只有3.14 % 的人关注了青少年数学之旅前两天&#xff0c;有位不愿意透露姓名的模友问了超模君一个问题&#xff1a;虽然这个问题超模君已经解答过无数遍了&#xff0c;但看到模友如此虔诚的态度&#xff0c;超模君决定今天再给模友们讲一个犹太小伙用数学征服美国军官的故…

使用 C# 开发浏览器扩展

使用 C# Blazor 开发浏览器扩展Intro前段时间听了 Justin 大佬分享的 Blazor 开发浏览器扩展&#xff0c;觉得很不错&#xff0c;C# 可以做更多有趣的事情了&#xff0c;很多需要在服务器端做的事情可能就可以在客户端里实现了&#xff0c;而且高度可以复用已有的 C# 代码&…

一个设置ip的vbs脚本

经常在两个网段间转换 常改ip&#xff0c;找了一个改ip的脚本稍微改了一下&#xff0c;让他适合我的情况&#xff08;自动判断我的ip&#xff09;strComputer "."SetobjWMIService GetObject("winmgmts:\\"&strComputer &"\root\cimv2")…

心动的本质是什么_《心动的信号3》:在“烟火气”里嗑糖,素人恋爱究竟有多上头?...

文 | 土豆2018年&#xff0c;一档画风清新&#xff0c;以素人恋爱为主体、辅之以明星观察为核心的恋爱社交真人秀节目&#xff0c;走红于市场。彼时国内综艺市场&#xff0c;尚且还处于竞技类真人秀、偶像综艺的爆发期——《心动的信号》播出以后&#xff0c;不仅成功开启了国内…

android 如何动态设置margin,Android 动态设置margin

android的view中有setPadding&#xff0c;但是没有直接的setMargin方法。如果要在代码中设置该怎么做呢&#xff1f;可以通过设置view里面的LayoutParams设置&#xff0c;而这个LayoutParams是根据该view在不同的GroupView而不同的。布局文件如下:xmlns:tools"http://sche…

公司服务器iSCSI网络硬盘连接故障

今天检查备份服务器工作状态&#xff0c;发现iSCSI硬盘连接出现了故障。然后刷新了一下系统状态&#xff0c;发现过了几秒钟后又重新连接上了。心里很疑惑&#xff0c;于是开始检查服务器日志。发现在9月13日凌晨4点20分左右有两个来源为l2nd的消息。稍前的一个信息告知网络控制…

老是担心数学学不好?是因为你的数学老师不是爱因斯坦!

各位模友&#xff0c;大家好我是小木相信上学的时候&#xff0c;数学对于很多人来说&#xff0c;无疑是个坑&#xff01;好不容易毕业了&#xff0c;好奇又好学的小表妹每次都能完美地引起小木的心酸历程。就在小木一边回忆起自己的心酸历程的同时&#xff0c;不禁感叹&#xf…

创业95%失败不是因项目本身

95%的人想过个人创业&#xff1b;95%的人一直只是停留在想象的阶段&#xff1b;95%的人创业失败&#xff1b;95%的失败不是因为项目本身的问题。 多年以前&#xff0c;就曾有句著名的口号&#xff1a;“十亿人民九亿商&#xff0c;还有一亿要开张。”中国人的个人创业意识普及…

oracle 产看执行计划_ODBA 技能SPM计划

OBA技能1-获取执行计划OBA技能2-执行计划顺序OBA技能&#xff13;-执行计划顺序表连接ODBA 技能&#xff14;实战执行计划ODBA 技能5 固定执行计划因为每次统计信息作业在收集完信息后&#xff0c;会触发ACS自适应游标管理程序&#xff0c;进行对绑定变量的窥探工作&#xff0c…

android动画设置的单位,Kotlin语言入门—实现单位转换,view设置,动画等

dp转换为px在android开发中&#xff0c;dp sp px之间的转换是不可避免的&#xff0c;在使用java语言开发时&#xff0c;往往会做个工具类进项转化。这样的工具类在网上很多&#xff0c;这里就不在展示了。如果使用Kotlin语言开发&#xff0c;则可以通过通过Extension来优雅的解…

微软面向初学者的机器学习课程:1.1-机器学习介绍

写在前面&#xff1a;最近在参与microsoft/ML-For-Beginners的翻译活动&#xff0c;欢迎有兴趣的朋友加入&#xff08;https://github.com/microsoft/ML-For-Beginners/issues/71&#xff09;机器学习介绍![机器学习&#xff0c;人工智能&#xff0c;深度学习-有什么区别?](ht…

margin-top绑架父节点问题的分析

转载至&#xff1a;http://www.benben.cc/blog/?p98 现象&#xff1a; 当两个空的块级元素嵌套时&#xff0c;如果内部的块设置有margin-top属性&#xff0c;而且父元素没有下边解决方法所述的特征&#xff0c;那么内部块的margin-top属性会绑架父元素&#xff08;即将margin-…

遭央视曝光的“AI算命”,背后竟然隐藏了一个价值千亿的市场!?

全世界只有3.14 % 的人关注了青少年数学之旅还记得儿时算命先生曾对我说&#xff1a;等你25岁那年&#xff0c;会黄袍加身&#xff0c;每天与大鱼大肉为伍。如今眼看着25逐步逼近&#xff0c;数据汪看到美团的外卖小哥都有种莫名的“亲切感”。爆红的“AI算命”言归正传&#x…

OnIntialDialog() (Dialog应用)和 OnIntialUpdate(View应用)的 程序起始点

Dialog为基的应用框架的程序的起始点在OnIntialDialog()FormView为基的应用框架的程序起始点在OnIntialUpdate() 把 需要起始就装入的代码放在 CformView&#xff1a;OnIntialUpdate();GetParentFrame()->RecalcLayout(); Resize ParenttoFit(); 三个语句之后&#xff08;上…

微软面向初学者的机器学习课程:1.2-机器学习的历史

写在前面&#xff1a;最近在参与microsoft/ML-For-Beginners的翻译活动&#xff0c;欢迎有兴趣的朋友加入&#xff08;https://github.com/microsoft/ML-For-Beginners/issues/71&#xff09;机器学习的历史作者Tomomi Imura[1]课前测验[2]在本课中&#xff0c;我们将走过机器学…

android布局中画圆角矩形,Android 自定义View之圆角矩形轨迹图

一、原理说明主要是通过计算轨迹的坐标点加入到集合中&#xff0c;然后对集合进行相应截取&#xff0c;传入canvas中。二、具体代码实现/*** 原理是先通过尺寸把各个轨迹的坐标计算出来&#xff0c;然后再截取相应坐标&#xff0c;进行重绘。** author lz* Time 2019-3-27*/pub…

类QQ右下角弹出框(Qt)

2019独角兽企业重金招聘Python工程师标准>>> 使用Qt写的类QQ右下角弹出框 /***main.cpp */ #include <QtGui/QApplication> #include "dialog.h"int main(int argc, char *argv[]) {QApplication a(argc, argv);Dialog w;w.show();return a.exec()…