//---------------------------------------------------------------------

 

  /// <summary>

  ///   Contains the parsed command line arguments. This consists of two

  ///   lists, one of argument pairs, and one of stand-alone arguments.

  /// </summary>

  public class CommandArgs

  {

      //---------------------------------------------------------------------

 

      private readonly Dictionary<string, string> mArgPairs = new Dictionary<string, string>();

 

      //---------------------------------------------------------------------

 

      private readonly List<string> mParams = new List<string>();

 

      /// <summary>

      ///   Returns the dictionary of argument/value pairs.

      /// </summary>

      public Dictionary<string, string> ArgPairs

      {

          get { return this.mArgPairs; }

      }

 

      /// <summary>

      ///   Returns the list of stand-alone parameters.

      /// </summary>

      public List<string> Params

      {

          get { return this.mParams; }

      }

  }

 

  //---------------------------------------------------------------------

 

  /// <summary>

  ///   Implements command line parsing

  /// </summary>

  public class CommandLine

  {

      //---------------------------------------------------------------------

 

      /// <summary>

      ///   Parses the passed command line arguments and returns the result

      ///   in a CommandArgs object.

      /// </summary>

      /// The command line is assumed to be in the format:

      /// 

      /// CMD [param] [[-|--|\]&lt;arg&gt;[[=]&lt;value&gt;]] [param]

      /// 

      /// Basically, stand-alone parameters can appear anywhere on the command line.

      /// Arguments are defined as key/value pairs. The argument key must begin

      /// with a '-', '--', or '\'. Between the argument and the value must be at

      /// least one space or a single '='. Extra spaces are ignored. Arguments MAY

      /// be followed by a value or, if no value supplied, the string 'true' is used.

      /// You must enclose argument values in quotes if they contain a space, otherwise

      /// they will not parse correctly.

      /// 

      /// Example command lines are:

      /// 

      /// cmd first -o outfile.txt --compile second \errors=errors.txt third fourth --test = "the value" fifth

      /// <param name="args"> array of command line arguments </param>

      /// <returns> CommandArgs object containing the parsed command line </returns>

      public static CommandArgs Parse(string[] args)

      {

          var kEqual = new char[] {'='};

 

          var kArgStart = new char[] {'-', '\\'};

 

          var ca = new CommandArgs();

 

          var ii = -1;

 

          var token = NextToken(args, ref ii);

 

          while (token != null)

          {

              if (IsArg(token))

              {

                  var arg = token.TrimStart(kArgStart).TrimEnd(kEqual);

 

                  string value = null;

 

                  if (arg.Contains("="))

                  {

                      // arg was specified with an '=' sign, so we need

 

                      // to split the string into the arg and value, but only

 

                      // if there is no space between the '=' and the arg and value.

 

                      var r = arg.Split(kEqual, 2);

 

                      if (r.Length == 2 && r[1] != string.Empty)

                      {

                          arg = r[0];

 

                          value = r[1];

                      }

                  }

 

                  while (value == null)

                  {

                      var next = NextToken(args, ref ii);

 

                      if (next != null)

                      {

                          if (IsArg(next))

                          {

                              // push the token back onto the stack so

 

                              // it gets picked up on next pass as an Arg

 

                              ii--;

 

                              value = "true";

                          }

 

                          else if (next != "=")

                          {

                              // save the value (trimming any '=' from the start)

 

                              value = next.TrimStart(kEqual);

                          }

                      }

                  }

 

                  // save the pair

 

                  ca.ArgPairs.Add(arg, value);

              }

 

              else if (token != string.Empty)

              {

                  // this is a stand-alone parameter. 

 

                  ca.Params.Add(token);

              }

 

              token = NextToken(args, ref ii);

          }

 

          return ca;

      }

 

      //---------------------------------------------------------------------

 

      /// <summary>

      ///   Returns True if the passed string is an argument (starts with 

      ///   '-', '--', or '\'.)

      /// </summary>

      /// <param name="arg"> the string token to test </param>

      /// <returns> true if the passed string is an argument, else false if a parameter </returns>

      private static bool IsArg(string arg)

      {

          return (arg.StartsWith("-") || arg.StartsWith("\\"));

      }

 

      //---------------------------------------------------------------------

 

      /// <summary>

      ///   Returns the next string token in the argument list

      /// </summary>

      /// <param name="args"> list of string tokens </param>

      /// <param name="ii"> index of the current token in the array </param>

      /// <returns> the next string token, or null if no more tokens in array </returns>

      private static string NextToken(string[] args, ref int ii)

      {

          ii++; // move to next token

 

          while (ii < args.Length)

          {

              var cur = args[ii].Trim();

 

              if (cur != string.Empty)

              {

                  // found valid token

 

                  return cur;

              }

 

              ii++;

          }

 

          // failed to get another token

 

          return null;

      }

  }

控制台解析命行C#的更多相关文章

  1. 使用ACE_Get_Opt解析命令行

    当我们用C++开发一些C++控制台小工具时,会需要一些用户输入的参数来决定程序如何工作和执行,而用户输入参数的方式大部分都是采用命令行参数的方式. 比如上一篇文章 玩转Windows服务系列--命令行 ...

  2. Chrome控制台输入多行js

    Chrome控制台输入多行js 分类: chrome2013-09-08 09:40 342人阅读 评论(0) 收藏 举报 控制台 Chrome控制台中回车默认是执行,要想输入换行,应按Enter+S ...

  3. boost之program_options库,解析命令行参数、读取配置文件

    一.命令行解析 tprogram_options解析命令行参数示例代码: #include <iostream> using namespace std; #include <boo ...

  4. ACE_Get_Opt解析命令行

    ACE_Get_Opt是一种解析命令行参数选项的迭代器. 1:构造方法 ACE_Get_Opt需要引用头文件,#include "ace/Get_Opt.h". ACE_Get_O ...

  5. shell解析命令行的过程以及eval命令

    本文说明的是一条linux命令在执行时大致要经过哪些过程?以及这些过程的大致顺序. 1.1 shell解析命令行 shell读取和执行命令时的大致操作过程如下图: 以执行以下命令为例: echo -e ...

  6. optparse模块解析命令行参数的说明及优化

    一.关于解析命令行参数的方法 关于“解析命令行参数”的方法我们一般都会用到sys.argv跟optparse模块.关于sys.argv,网上有一篇非常优秀的博客已经介绍的很详细了,大家可以去这里参考: ...

  7. python解析命令行参数

    常常需要解析命令行参数,经常忘记,好烦,总结下来吧. 1.Python 中也可以所用 sys 的 sys.argv 来获取命令行参数: sys.argv 是命令行参数列表 参数个数:len(sys.a ...

  8. C#/.NET 使用 CommandLineParser 来标准化地解析命令行

    CommandLineParser 是一款用于解析命令行参数的 NuGet 包.你只需要关注你的业务,而命令行解析只需要极少量的配置代码. 本文将介绍如何使用 CommandLineParser 高效 ...

  9. 使用 Apache Commons CLI 解析命令行参数示例

    很好的输入参数解析方法 ,转载记录下 转载在: https://www.cnblogs.com/onmyway20xx/p/7346709.html Apache Commons CLI 简介 Apa ...

随机推荐

  1. Reading RxJava Marble Diagrams

    ------>表示一个Observable(承时间推移,由左入右,左边item先发射) ------>上面的图形,表示这个Observable发射的item ------>上的的|( ...

  2. Objective-C 的 self 和 super 详解 (用简单程序说明问题)

    在 Objective-C 中的类实现中经常看到这两个关键字 "self" 和 "super",以以前 oop 语言的经验,拿 c++ 为例,self 相当于 ...

  3. linux驱动模块编译(初学者)

    inux 模块编译步骤(转) 本文将直接了当的带你进入linux的模块编译.当然在介绍的过程当中,我也会添加一些必要的注释,以便初学者能够看懂.之所以要写这篇文章,主要是因为从书本上学的话,可能要花更 ...

  4. android 命名规则

    包名结构: 资源命名方式:

  5. 介绍个好点的,JAVA技术群

    java技术交流,意义是以QQ群为媒介,添加一些有多年工作经验和技术的人群,为有问题的人群解答在工作中遇到的各种问题为思想,java技术交流群号161571685,创建时间为2010年,走过将近5年的 ...

  6. 使用Dom4j操作XML数据

    --------------siwuxie095                             dom4j 是一个非常优秀的 Java XML 的 API, 用来读写 XML 文件 和操作 ...

  7. cocos2d-x 初探helloWorld

    cocos2d-x的main函数代码很少,把一些复杂的接口封装到AppDelegate类里了,“AppDelegate”从词意可以得出是app的代理类,而一些最早的场景都会在AppDelegate类里 ...

  8. 面试题:ConcurrentHashMap实现线程安全的原理

    在ConcurrentHashMap没有出现以前,jdk使用hashtable来实现线程安全,但是hashtable是将整个hash表锁住,所以效率很低下. ConcurrentHashMap将数据分 ...

  9. Linux ekho

    一.简介 Ekho(余音)是一个免费.开源的中文语音合成软件.它目前支持粤语.普通话(国语).诏安客语.藏语.雅言(中国古代通用语)和韩语(试验中),英文则通过Festival间接实现.Ekho支持L ...

  10. El表达式 (先大致的记录下吧!以后慢慢深入)

    参考:http://blog.csdn.net/eson_15/article/details/51264269 1.获取数据采用 ${标识符} 的形式 request.setAttribute(&q ...