1. 程式人生 > >linux 中解析命令列引數(getopt_long用法)

linux 中解析命令列引數(getopt_long用法)

getopt_long支援長選項的命令列解析,使用man getopt_long,得到其宣告如下:

  #include <getopt.h>

  int getopt_long(int argc, char * const argv[],

  const char *optstring,

  const struct option *longopts, int *longindex);

  int getopt_long_only(int argc, char * const argv[],

  const char *optstring,

  const struct option *longopts, int *longindex);

  說明:函式中的argc和argv通常直接從main()到兩個引數傳遞而來。optsting是選項引數組成的字串,如

  果該字串裡任一字母后有冒號,那麼這個選項就要求有引數。下一個引數是指向陣列的指標,這個陣列是

  option結構陣列,option結構稱為長選項表,其宣告如下:

  struct option {

  const char *name;

  int has_arg;

  int *flag;

  int val;

  };

  結構中的元素解釋如下:

  const char *name:選項名,前面沒有短橫線。譬如"help"、"verbose"之類。

  int has_arg:描述長選項是否有選項引數,如果有,是哪種型別的引數,其值見下表:

  符號常量             數值            含義

  no_argument            0            選項沒有引數

  required_argument      1            選項需要引數

  optional_argument      2            選項引數是可選的

  int *flag:

  如果該指標為NULL,那麼getopt_long返回val欄位的值;

  如果該指標不為NULL,那麼會使得它所指向的結構填入val欄位的值,同時getopt_long返回0

  int val:

  如果flag是NULL,那麼val通常是個字元常量,如果短選項和長選項一致,那麼該字元就應該與optstring中

  出現的這個選項的引數相同;

  最後一個引數:longindex引數一般賦為NULL即可;如果沒有設定為NULL,那麼它就指向一個變數,這個變數

  會被賦值為尋找到的長選項在longopts中的索引值,這可以用於錯誤診斷。

  注:GNU提供的getopt-long()和getopt-long-only()函式,其中,後者的長選項字串是以一個短橫線開始的

  ,而非一對短橫線。

  linux 命令列約定:

  幾乎所有的GNU/Linux程式都遵循一些命令列引數定義的約定。程式希望出現的引數可以分成兩種:選

  項(options or flags)、其他型別的的引數。Options修飾了程式執行的方式,其他型別的引數則提供了輸

  入(例如,輸入檔案的名稱)。

  對於options型別引數可以有兩種方式:

  1)短選項(short options):顧名思義,就是短小引數。它們通常包含一個連字號和一個字母(大寫

  或小寫字母)。例如:-s,-h等。

  2)長選項(long options):長選項,包含了兩個連字號和一些大小寫字母組成的單詞。例如,--

  size,--help等。

  *注:一個程式通常會提供包括short options和long options兩種引數形式的引數。

  對於其他型別引數的說明:

  這種型別的引數,通常跟隨在options型別引數之後。例如,ls –s /功能為顯示root目錄的大小。’/

  ’這個引數告訴ls要顯示目錄的路徑。

  getopt_long()函式使用規則:

  (1)使用前準備兩種資料結構

  字元指標型變數

  該資料結構包括了所有要定義的短選項,每一個選項都只用單個字母表示。如果該選項需要引數(如,

  需要檔案路徑等),則其後跟一個冒號。例如,三個短選項分別為‘-h’‘-o’‘-v’,其中-o需要引數,

  其他兩個不需要引數。那麼,我們可以將資料結構定義成如下形式:

  const char * const shor_options = “ho:v” ;

  struct option 型別陣列

  該資料結構中的每個元素對應了一個長選項,並且每個元素是由四個域組成。通常情況下,可以按以下

  規則使用。第一個元素,描述長選項的名稱;第二個選項,代表該選項是否需要跟著引數,需要引數則為1,

  反之為0;第三個選項,可以賦為NULL;第四個選項,是該長選項對應的短選項名稱。另外,資料結構的最後

  一個元素,要求所有域的內容均為0,即{NULL,0,NULL,0}。下面舉例說明,還是按照短選項為‘-h’‘-o’

  ‘-v’的例子,該資料結構可以定義成如下形式:

  const struct option long_options = {

  {  “help”,      0,   NULL,   ‘h’  },

  {  “output”,    1,   NULL,   ‘o’  },

  {  “verbose”,   0,   NULL,   ‘v’  },

  {  NULL,      0,    NULL,   0  }

  };

  (2)呼叫方法

  參照(1)準備的兩個資料結構,則呼叫方式可為:

  getopt_long( argc, argv, short_options, long_options, NULL);

  (3)幾種常見返回值

  (a)每次呼叫該函式,它都會分析一個選項,並且返回它的短選項,如果分析完畢,即已經沒有選項了,

  則會返回-1。

  (b)如果getopt_long()在分析選項時,遇到一個沒有定義過的選項,則返回值為‘?’,此時,程式設計師可

  以打印出所定義命令列的使用資訊給使用者。

  (c)當處理一個帶引數的選項時,全域性變數optarg會指向它的引數

  (d)當函式分析完所有引數時,全域性變數optind(into argv)會指向第一個‘非選項’的位置

  實踐小例子:

  view plaincopy to clipboardprint?

  #include <stdio.h>

  #include <getopt.h>

  char *l_opt_arg;

  char* const short_options = "nbl:";

  struct option long_options[] = {

  { "name",     0,   NULL,    'n'     },

  { "bf_name",  0,   NULL,    'b'     },

  { "love",     1,   NULL,    'l'     },

  {      0,     0,     0,     0},

  };

  int main(int argc, char *argv[])

  {

  int c;

  while((c = getopt_long (argc, argv, short_options, long_options, NULL)) != -1)

  {

  switch (c)

  {

  case 'n':

  printf("My name is XL./n");

  break;

  case 'b':

  printf("His name is ST./n");

  break;

  case 'l':

  l_opt_arg = optarg;

  printf("Our love is %s!/n", l_opt_arg);

  break;

  }

  }

  return 0;

  }

  #include <stdio.h>

  #include <getopt.h>

  char *l_opt_arg;

  char* const short_options = "nbl:";

  struct option long_options[] = {

  { "name",     0,   NULL,    'n'     },

  { "bf_name",  0,   NULL,    'b'     },

  { "love",     1,   NULL,    'l'     },

  {      0,     0,     0,     0},

  };

  int main(int argc, char *argv[])

  {

  int c;

  while((c = getopt_long (argc, argv, short_options, long_options, NULL)) != -1)

  {

  switch (c)

  {

  case 'n':

  printf("My name is XL./n");

  break;

  case 'b':

  printf("His name is ST./n");

  break;

  case 'l':

  l_opt_arg = optarg;

  printf("Our love is %s!/n", l_opt_arg);

  break;

  }

  }

  return 0;

  }

  編譯並執行:

  [[email protected] liuxltest]# gcc -o getopt getopt.c

  [[email protected] liuxltest]# ./getopt -n -b -l forever

  My name is XL.

  His name is ST.

  Our love is forever!

  [[email protected] liuxltest]#

  [[email protected] liuxltest]# ./getopt -nb -l forever

  My name is XL.

  His name is ST.

  Our love is forever!

  [[email protected] liuxltest]# ./getopt -nbl forever

  My name is XL.

  His name is ST.

  Our love is forever!

相關推薦

linux 解析命令引數(getopt_long用法)

getopt_long支援長選項的命令列解析,使用man getopt_long,得到其宣告如下:   #include <getopt.h>   int getopt_long(int argc, char * const argv[],   const cha

linuxgetopt_long解析命令引數(附上windows上的getopt_long原始碼)

     getopt_long支援長選項的命令列解析,使用man getopt_long,得到其宣告如下:       #include <getopt.h>       int getopt_long(int argc, char * const argv[

get_optlong用法linux解析命令引數

const char * const shor_options = “ho:v” ;struct option 型別陣列該資料結構中的每個元素對應了一個長選項,並且每個元素是由四個域組成。通常情況下,可以按以下規則使用。第一個元素,描述長選項的名稱;第二個選項,代表該選項是否需要跟著引數,需要引數則為1,反

getopt、getopt_long和getopt_long_only解析命令引數

一:posix約定:          下面是POSIX標準中關於程式名、引數的約定:          程式名不宜少於2個字元且不多於9個字元;          程式名應只包含小寫字母和阿拉伯數字;          選項名應該是單字元或單數字,且以短橫 ‘-’ 為

3.QTQCommandLineParser和QCommandLineOption解析命令引數

 1新建專案 main.cpp #include<QCoreApplication> #include<QCommandLineParser>

FFmpeg 解析命令引數

FFmpeg 命令列基礎語法: ffmpeg [global_options] {[input_file_options] -i input_file}...{[output_file_options] output_file}... global_options:全域性引

go語言解析命令引數的實現

一、實現程式碼如下 // fffggg project main.go package main import (     "flag"     "fmt" ) func main() {     var num int     var mode string   

linuxyum命令的使用

yum介紹 yum命令是在Fedora和RedHat以及SUSE中基於rpm的軟體包管理器,它可以使系統管理人員互動和自動化地更細與管理RPM軟體包,能夠從指定的伺服器自動下載RPM包並且安裝,可以自動處理依賴性關係,並且一次安裝所有依賴的軟體包,無須繁瑣地一次

Python解析命令引數

使用Python編寫應用程式或是指令碼的時候,經常會用到命令列引數。C語言中有庫函式getopt解析短命令列引數,使用getopt_long解析短命令和長命令的組合。 Python使用getopt模組,同時解析短命令和長命令。看具體使用例子 #!/usr/bin/python import sys

學以致用——Java原始碼——命令引數用法示例(任意個數字連乘)(Command-Line Arguments)

參考文章: 1. 命令列中執行帶引數的java程式(Command-Line Arguments),https://blog.csdn.net/hpdlzu80100/article/details/51851440  2. 學以致用——Java原始碼——使

Spring boot 梳理 - 在bean使用命令引數-自動裝配ApplicationArguments

If you need to access the application arguments that were passed to SpringApplication.run(…​), you can inject a org.springframework.boot.ApplicationArgumen

pycharm傳入命令引數

參考網址: 設定的地方: Run/Debug Configurations->Configurations->Script Parames 和vs類似,都不用輸入程式名字,直接輸入引數即可。 如,在命令列中需要輸入 python a.py b c d 則在上述地方直接輸入 b c d就行了

Linux使用命令方式呼叫openoffice服務將word檔案轉為PDF

Linux中使用命令列方式呼叫openoffice服務將word檔案轉為PDF 測試安裝之後的openoffice用命令將docx檔案轉換為PDF   需要一份python的指令碼程式,因為轉換需要通過py程式去呼叫api處理,將下面程式儲存到topdf.py檔案: #

python處理命令引數的模組optpars

optpars是python中用來處理命令列引數的模組,可以自動生成程式的幫助資訊,功能強大,易於使用,可以方便的生成標準的,符合Unix/Posix 規範的命令列說明。使用 add_option() 來加入選項,使用 parse_args() 來解析命令列。add_opti

Google gflags庫(解析命令引數

google gflags是google使用的一個開源庫,用於解析命令列標記。目前的gflags有C++和Python兩個版本。本文主要介紹gflags的C++版本使用方法。 命令列標記是指使用者在執行可執行程式時,在命令列中指定的引數。例如,對於命令: fgre

Python處理命令引數

Python文件中的例子: import getopt, sys def main():     try:         opts, args = getopt.getopt(sys.argv[1:], "ho:v", ["help", "output="])     except getopt.Ge

在遠端桌面連線使用命令引數

mstsc [<connection file>] [/v:<server[:port]>] [/admin] [/f[ullscreen]] [/w:<width>] [/h:<height>] [/public] | [/span] [/edit "co

PHP 接收命令引數

1.$argvPHP 的二進位制檔案(php.exe 檔案)及其執行的 PHP 指令碼能夠接受一系列的引數。PHP 沒有限制傳送給指令碼程式的引數的個數(外殼程式對命令列的字元數有限制,但通常都不會超過該限制)。傳遞給指令碼的引數可在全域性變數 $argv 中獲取。該陣

C語言-解析命令引數

#include <stdio.h> #include<unistd.h> /* 函式說明 : int getopt(int argc,char * const argv[ ],const char * optstring);) 用來分析命令

使用 Qt 解析命令引數

Qt解析命令列 我們使用 Python 寫個簡單的指令碼很方便,直接 import argparse 就能很容易的實現命令列引數解析的功能,還可以通過 --help 來輸出幫助功能,而 Qt5 頁提供了這方面的支援。 Qt 從 Qt5.2之後提供了 QCom