设为首页 收藏本站
查看: 1100|回复: 0

[经验分享] 在 Perl 中使用 Getopt::Long 模块来接收用户命令行参数

[复制链接]

尚未签到

发表于 2018-8-31 09:32:16 | 显示全部楼层 |阅读模式
  原文出处:http://www.php-oa.com/2009/04/04/perl_getopt-long.html
  我们在linux常常用到一个程序需要加入参数,现在了解一下 perl 中的有关控制参数的模块 Getopt::Long ,比直接使用 @ARGV 的数组强大多了.我想大家知道在 Linux 中有的参数有二种形式.


  • 长参数  –help
  • 短参数   -h
  也就是-和–的分别.–表示完整参数.-表示简化参数.在 Perl 的这个模块中也支持这二种方法.
  
这要介绍的二 Getopt 其实有二个模块,一个叫 Getopt::Long 一个叫 Getopt::Std.下面就只介绍 Getopt::Long 了.因为这个模块更加强大

Getopt::Long 模块
  初始化 Perl命令行中所接受的参数,简化了命令行参数的解析.下面看程序的例子.
  


  • #!/usr/bin/perl
  • use strict;
  • use Getopt::Long;
  • use Smart::Comments;

  • my @libs    = ();
  • my %flags   = ();
  • my ( $verbose, $all, $more, $diam, $debug, $test, $step);

  • GetOptions(
  •         'verbose+'  => \$verbose,
  •         'more!'     => \$more,
  •         'debug:i'   => \$debug,
  •         'lib=s'     => \@libs,
  •         'flag=s'    => \%flags,
  •         'test|t'    => \$test,
  •         'all|everything|universe' => $all,
  • );

  • ### $verbose
  • ### $more
  • ### $debug
  • ### $test
  • ### @libs;
  • ### %flags
  

  这就是使用的方法,下面是详细解释,注意看 GetOptions 中的 => 前面的部分.下面是详解


  • ‘verbose+’  接有 + 的选项不接收变量,后面不需要加内容.直接使用就行了,会在每次出现时增加一次变量,就是讲命行时在参数中 -verbose -verbose 出现二次时 verbose 的值就会变成 2.
  • ‘more!’        接有 ! 的选项不接收变量(也就是讲后面不需要加参数 –more 来使用就行了),只要命令行中出现了这个参数,就会默认是 1 ,是用来设置打开和关掉一个功能的>.可以在参数前加 no 变成负的例如-nomore.
  • ‘flag=s’        接有 = 的字符串要求接字符串(s)、整数(i),或者浮点(f)等类型的变量.
  • ‘debug:i’      接有 : 的选项会接受缺省为0或者为空字符串的可选变量
  • ‘test|t’          接有 | 的选项表示可以给 –test 简写为 -t.


  • ‘lib=s’     => @libs    如果相关联的变量是个数组, 如这个地方的 @libs, 那么选项可以多次出现, 值可以被推到数组里.
  • ‘flag=s’    => %flags  如果相关联的变量是个散列, 那么就要求一个键=值(key=value)对, 并被插入到散列里.
  备注:
  
     在匹配参数名的时候,GetOptions 在缺省设置下会忽略大小写,默认参数被简写为唯一的最短字符串(首字母)(例如,-m 代表 -more. 相同的首字母时,会加上第二个字母来区分)

Getopt 模块的程序使用的方法:
  根据上面的例子,比如我们写了一个程序叫 test.pl .我们只需要在命令行中加如下参数:
  


  • $ ./test.pl  --verbose --verbose -v --more \
  •       --lib='/lib' -l '/lib64' --f a=1 --flag b=2  --debug 2 -t fukai
  

  有点小长,在看看上面的,就会明白意思了.在这个地方,我使用了 Smart::Comment 模块,所以在最下面的 ###  是会输出这个变量本身的内容的.这也是一个超级强大的模块.我们来看看输入这些参数后.会输出什么内容吧.
  


  • ### $verbose: 3
  • ### $more: 1
  • ### $debug: 2
  • ### @libs: [
  • ###          '/lib',
  • ###          '/lib64'
  • ###        ]
  • ### %flags: {
  • ###           a => '1',
  • ###           b => '2'
  • ###         }
  

  在对一下上面输入的参数,明白了吧.

Getopt 模块的简单总结
  (1. 带值参数传入程序内部
  
※参数类型:整数, 浮点数, 字串
  


  • GetOptions(
  •     'tag=s' => \$tag
  • );
  

  ‘=’表示此参数一定要有参数值, 若改用’:'代替表示参数不一定要有参数值
  
‘s’表示传递字串参数, 若为’i'表传递整数参数, 若为’f'表传递浮点数.
  
带值参数使用的方法
  


  • $ test.pl --tag=string
  • $ test.pl --tag string
  

  (2. 需要传送多个值的参数到程序中.
  
比如需要传几个值到 @libfiles 中的操作方法.
  


  • GetOptions ("library=s" => \@libfiles);
  • GetOptions ("library=s@" => \$libfiles);
  

  参数传到 @$tag
  
使用的方法
  


  • $ test.pl --library lib/stdlib --library lib/extlib
  

  (3. 对键值对的参数传递
  
有时我们需要传送一些键值对到程序中进行处理,就需要使用到这个功能了.
  


  • GetOptions ("define=s" => \%defines);
  • GetOptions ("define=s%" => \$defines);
  

  使用的方法
  


  • $ test.pl --define os=linux --define vendor=redhat
  

  (4. 参数的别名
  
我们需要参数加个简写之类的别名时,可以使用下面的方法
  


  • GetOptions ('length|height=f' => \$length);
  

  第一个名称为 primary name, 其他的名称为 alias(可有多个alias名称) ,当使用hash参数时, 使用primary name作为key值



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-559206-1-1.html 上篇帖子: perl文件测试运算符 下篇帖子: 用perl去掉Unicode换行字符
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表