zoukankan      html  css  js  c++  java
  • 命令行参数库:McMaster.Extensions.CommandLineUtils【转】

    转:https://cloud.tencent.com/developer/article/1341303

    命令行参数解析想必是每一个命令行程序都难以避开的工程。这工程可小可大,但每次都写始终是在浪费时间。而且,不同人实现也千差万别,使得不同的命令行程序命令参数传入的体验总有差异。
    于是安利一款命令行工具库——McMaster.Extensions.CommandLineUtils,它符合当下各大主流命令行工具的参数体验;而且,代码非常简洁。
    Microsoft.Extensions.CommandlineUtils是微软出品;不过微软官方已经在 GitHub 上将此命令行项目重定向到了 aspnet/Common,原有的单独的命令行不复存在。
    McMaster.Extensions.CommandLineUtils 是微软官方指定的命令行仓库的正统 Folk 版本。

    它的仓库和 NuGet 包
    GitHub: https://github.com/natemcmaster/CommandLineUtils
    NuGet: https://www.nuget.org/packages/McMaster.Extensions.CommandLineUtils

    我正在自己的项目中采用这款库,项目名为 mdmeta,用于自动生成 Markdown 前的元数据标签,写博客非常方便。

    体验主流的命令行参数体验

    # 不带任何参数
    mdmeta
    # 一个简单的命令
    mdmeta echo
    # 一个带参数(Argument)的简单的命令
    mdmeta echo "Hello!"
    # 一个带选项(Option)的简单命令
    mdmeta echo --upper
    # 一个带参数(Argument)带选项(Option)且选项中带值的简单命令
    mdmeta echo "Hello!" -s ", "
    # 一个带参数(Argument)带多种选项(Option)且部分选项中带多个值的简单命令
    mdmeta echo "Hello!" --repeat-count=3 -s ", " -s "| "
    

    体验库的 Builder API
    McMaster.Extensions.CommandLineUtils 使用 Builder API 配出以上的命令,代码非常简洁。

    static int Main(string[] args)
    {
        var app = new CommandLineApplication{Name = "mdmeta"};
        app.HelpOption("-?|-h|--help");
        app.OnExecute(() =>
        {
            app.ShowHelp();
            return 0;
        });
        app.Command("echo", command =>
        {
            command.Description = "输出用户输入的文字。";
            command.HelpOption("-?|-h|-help");
            var wordsArgument = command.Argument("[words]", "指定需要输出的文字。");
            var repeatOption = command.Option("-r|--repeat-count", "指定输出重复次数", CommandOptionType.SingleValue);
            var upperOption = command.Option("--upper", "指定是否全部大写", CommandOptionType.NoValue);
            var separatorOption = command.Option("-s|--separator", "指定重复输出用户文字时重复之间应该使用的分隔符,可以指定多个,这将依次应用到每一次分割。", CommandOptionType.MultipleValue);
            command.OnExecute(() =>
            {
                // 在这里使用上面各种 Argument 和 Option 的 Value 或 Values 属性拿值。
                return 0;
            });
        });
        return app.Execute(new []{"-?"});
    }
    

    体验我封装的命令行参数配置
    原生库配置命令行参数已经非常方便了,几乎是一行一个功能,但 lambda 表达式嵌套太多是一个问题,会导致代码随着参数种类的增多变得急剧膨胀;于是我针对原生库做了一个基于反射的版本。于是,实现一个命令行参数只需要写这些代码就够啦:

    更新:McMaster.Extensions.CommandLineUtils 接手微软之后,也添加了 Attribute 的 API,使用方法与下面的大同小异。

    [CommandMetadata("echo", Description = "Output users command at specified format.")]
    public sealed class SampleTask : CommandTask
    {
        private int _repeatCount;
    
        [CommandArgument("[words]", Description = "The words the user wants to output.")]
        public string Words { get; set; }
    
        [CommandOption("-r|--repeat-count", Description = "Indicates how many times to output the users words.")]
        public string RepeatCountRaw
        {
            get => _repeatCount.ToString();
            set => _repeatCount = value == null ? 1 : int.Parse(value);
        }
        
        [CommandOption("--upper", Description = "Indicates that whether all words should be in upper case.")]
        public bool UpperCase { get; set; }
    
        [CommandOption("-s|--separator", Description = "Specify a string to split each repeat.")]
        public List<string> Separators { get; set; }
    
        public override int Run()
        {
            // 当用户敲入的命令已准备好,上面的参数准备好,那么这个函数就会在这里执行啦。
            return 0;
        }
    }
    

    你一定会吐槽代码变多了。确实如此!但是,当命令的种类和参数的种类变得急剧膨胀的时候,这种方式可以将各种命令都隔离开来。于是,你只需要专注于实现自己的命令就好啦!

    将以下这些文件放入自己的项目中即可立刻写出上面的代码(注意 Main 函数也是需要的,因为它启动了反射):

    如果发现这一行的后面不是代码,那么极有可能是被不小心屏蔽了,请手动访问:gitee.com/codes。

    支持的平台
    支持 .Net Standard 1.3,这意味着 .Net Core 可以使用,.NET Framework 4.5.1 及以上即可使用。这意味着可以很随意地跨全平台。

  • 相关阅读:
    winform窗口打开特效及窗口位置居中
    C# Installer Projects 打包工具
    C#
    MVVM模式开发WinForm-ReactiveUI
    C#实现类似百度网盘、育网校园云盘在“我的电脑”磁盘驱动器
    MVVM框架
    自制2048小游戏
    一个无限循环轮播图 HCCycleView
    Xcode插件及cocoapods不能正常使用的解决方法
    Runtime — 运行时机制
  • 原文地址:https://www.cnblogs.com/fanfan-90/p/15062609.html
Copyright © 2011-2022 走看看