當前位置: 首頁>>代碼示例>>Python>>正文


Python getopt.gnu_getopt方法代碼示例

本文整理匯總了Python中getopt.gnu_getopt方法的典型用法代碼示例。如果您正苦於以下問題:Python getopt.gnu_getopt方法的具體用法?Python getopt.gnu_getopt怎麽用?Python getopt.gnu_getopt使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在getopt的用法示例。


在下文中一共展示了getopt.gnu_getopt方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: ParseArguments

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def ParseArguments(argv):
  """Parses command-line arguments.

  Args:
    argv: Command-line arguments, including the executable name, used to
      execute this application.

  Returns:
    Tuple (args, option_dict) where:
      args: List of command-line arguments following the executable name.
      option_dict: Dictionary of parsed flags that maps keys from DEFAULT_ARGS
        to their values, which are either pulled from the defaults, or from
        command-line flags.
  """
  option_dict = DEFAULT_ARGS.copy()

  try:
    opts, args = getopt.gnu_getopt(argv[1:], OPTIONS, LONG_OPTIONS)
  except getopt.GetoptError, e:
    print >>sys.stderr, 'Error: %s' % e
    PrintUsageExit(1) 
開發者ID:elsigh,項目名稱:browserscope,代碼行數:23,代碼來源:dev_appserver_main.py

示例2: test_gnu_getopt

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def test_gnu_getopt(self):
        # Test handling of GNU style scanning mode.
        cmdline = ['-a', 'arg1', '-b', '1', '--alpha', '--beta=2']

        # GNU style
        opts, args = getopt.gnu_getopt(cmdline, 'ab:', ['alpha', 'beta='])
        self.assertEqual(args, ['arg1'])
        self.assertEqual(opts, [('-a', ''), ('-b', '1'),
                                ('--alpha', ''), ('--beta', '2')])

        # recognize "-" as an argument
        opts, args = getopt.gnu_getopt(['-a', '-', '-b', '-'], 'ab:', [])
        self.assertEqual(args, ['-'])
        self.assertEqual(opts, [('-a', ''), ('-b', '-')])

        # Posix style via +
        opts, args = getopt.gnu_getopt(cmdline, '+ab:', ['alpha', 'beta='])
        self.assertEqual(opts, [('-a', '')])
        self.assertEqual(args, ['arg1', '-b', '1', '--alpha', '--beta=2'])

        # Posix style via POSIXLY_CORRECT
        self.env["POSIXLY_CORRECT"] = "1"
        opts, args = getopt.gnu_getopt(cmdline, 'ab:', ['alpha', 'beta='])
        self.assertEqual(opts, [('-a', '')])
        self.assertEqual(args, ['arg1', '-b', '1', '--alpha', '--beta=2']) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:27,代碼來源:test_getopt.py

示例3: parsearg

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def parsearg():
    try:
        options, args = getopt.gnu_getopt(sys.argv[1:], 'f:p:F:?hd', 'help')
        configfile = None
        pidfile = '/var/run/vlcp.pid'
        daemon = False
        fork = None
        for k,v in options:
            if k == '--help' or k == '-?' or k == '-h':
                usage()
            elif k == '-f':
                configfile = v
            elif k == '-p':
                pidfile = v
            elif k == '-d':
                daemon = True
            elif k == '-F':
                fork = int(v)
        startup = None
        if args:
            startup = args
        return (configfile, daemon, pidfile, startup, fork)
    except getopt.GetoptError as exc:
        print(exc)
        usage() 
開發者ID:hubo1016,項目名稱:vlcp,代碼行數:27,代碼來源:start.py

示例4: main

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def main():
    option_list = 'region= type= role= key= volume= ami= bootstrap='.split()
    try:
        opts, args = getopt.gnu_getopt(sys.argv[1:], '', option_list)
    except:
        usage()
        sys.exit(2)
    if len(args) > 0:
        if args[0] == 'configure':
            configure()
        elif args[0] in os_list:
            try:
                launch(opts, args[0])
            except NoCredentialsError:
                advise_credentials()
            except:
                troubleshoot()
        elif args[0] == 'help':
            usage()
        else:
            usage()
    else:
        usage() 
開發者ID:awslabs,項目名稱:aws-support-tools,代碼行數:25,代碼來源:qi.py

示例5: main

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def main():
  try:
    opts, args = getopt.gnu_getopt(sys.argv[1:], 'ho', ['help', 'output='])
  except getopt.GetoptError:
    Usage()
    sys.exit(2)
  try:
    user = args[0]
  except:
    Usage()
    sys.exit(2)
  output = None
  for o, a in opts:
    if o in ("-h", "--help"):
      Usage()
      sys.exit(2)
    if o in ("-o", "--output"):
      output = a
  FetchTwitter(user, output) 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:21,代碼來源:twitter-to-xhtml.py

示例6: parse_args

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def parse_args(query=''):
  query = query.split()
  dic = {
    'isUpdate': False,
    'platform': default_platform,
    'command': ''
  }
  try:
    opts, args = getopt.gnu_getopt(query, 'uo:')
  except:
    return dic

  for opt, arg in opts:
    if opt == '-u':
      dic['isUpdate'] = True
    elif opt == '-o':
      dic['platform'] = arg

  dic['command'] = '-'.join(args)

  return dic 
開發者ID:cs1707,項目名稱:tldr-alfred,代碼行數:23,代碼來源:tldr.py

示例7: main

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def main(cls):
        short_opts = 'f:h?'
        long_opts = ['help']
        short_dict = {}
        for opt in cls.options:
            hasarg = len(opt) < 3 or opt[2]
            if hasarg:
                if len(opt) > 1 and opt[1]:
                    short_opts += opt[1] + ':'
                    short_dict[opt[1]] = opt[0]
                long_opts.append(opt[0] + '=')
            else:
                if len(opt) > 1 and opt[1]:
                    short_opts += opt[1]
                    short_dict[opt[1]] = opt[0]
                long_opts.append(opt[0])
        try:
            options, args = getopt.gnu_getopt(sys.argv[1:], short_opts, long_opts)
        except Exception as exc:
            print(str(exc))
            print()
            print(cls.__doc__)
            sys.exit(2)
        else:
            opt_dict = {}
            configfile = None
            for k,v in options:
                if k == '--help' or k == '-?' or k == '-h':
                    print(cls.__doc__)
                    sys.exit(0)
                elif k == '-f':
                    configfile = v
                else:
                    if k.startswith('--'):
                        opt_dict[k[2:]] = v
                    else:
                        opt_dict[short_dict[k[1:]]] = v
            from vlcp.config import manager
            manager['main.args'] = args
            manager['main.kwargs'] = opt_dict
            server_main(configfile, ('__main__.' + cls.__name__,)) 
開發者ID:hubo1016,項目名稱:vlcp,代碼行數:43,代碼來源:script.py

示例8: __find_options_to_extend__

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def __find_options_to_extend__(long_options):
	options_to_extend = []

	for num, arg in enumerate(long_options):
		arg = arg.split(":")
		if len(arg) == 2:
			long_options[num] = arg[0] + "="
			options_to_extend.append(("--" + arg[0], arg[1]))

	return options_to_extend

# This is a duplicate of gnu_getopt, but with support for optional arguments in long options, in the form; "arg:default_value". 
開發者ID:ejwa,項目名稱:gitinspector,代碼行數:14,代碼來源:optval.py

示例9: gnu_getopt

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def gnu_getopt(args, options, long_options):
	options_to_extend = __find_options_to_extend__(long_options)

	for num, arg in enumerate(args):
		opt = __find_arg_in_options__(arg, options_to_extend)
		if opt:
			args[num] = arg + "=" + opt[1]

	return getopt.gnu_getopt(args, options, long_options) 
開發者ID:ejwa,項目名稱:gitinspector,代碼行數:11,代碼來源:optval.py

示例10: __init__

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def __init__(self, optspec, optfunc=getopt.gnu_getopt,
                 onabort=_default_onabort):
        self.optspec = optspec
        self._onabort = onabort
        self.optfunc = optfunc
        self._aliases = {}
        self._shortopts = 'h?'
        self._longopts = ['help', 'usage']
        self._hasparms = {}
        self._defaults = {}
        self._usagestr = self._gen_usage() 
開發者ID:omererdem,項目名稱:honeything,代碼行數:13,代碼來源:options.py

示例11: get_config

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def get_config():
    shortopts = 'hs:o:t:n:c'
    longopts = ['help', 'cname']

    try:
        optlist, args = getopt.gnu_getopt(sys.argv[1:], shortopts, longopts)
    except getopt.GetoptError as e:
        print(e)
        print_help()
        sys.exit(1)

    global config
    for key, value in optlist:
        if key == '-s':
            config['dns'] = value
        elif key == '-o':
            config['outfile'] = value
        elif key == '-t':
            config['querytype'] = value
        elif key in ('-c', '--cname'):
            config['cname'] = True
        elif key == '-n':
            config['threadnum'] = int(value)
        elif key in ('-h', '--help'):
            print_help()
            sys.exit(0)

    if len(args) != 1:
        print("You must specify the input hosts file (only one).")
        sys.exit(1)

    config['infile'] = args[0]
    if config['outfile'] == '':
        config['outfile'] = config['infile'] + '.out' 
開發者ID:lennylxx,項目名稱:ipv6-hosts,代碼行數:36,代碼來源:update_hosts.py

示例12: main

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def main():
  try:
    shortflags = 'h'
    longflags = ['help', 'username=', 'password=', 'encoding=']
    opts, args = getopt.gnu_getopt(sys.argv[1:], shortflags, longflags)
  except getopt.GetoptError:
    PrintUsageAndExit()
  usernameflag = None
  passwordflag = None
  encoding = None
  for o, a in opts:
    if o in ("-h", "--help"):
      PrintUsageAndExit()
    if o in ("--username"):
      usernameflag = a
    if o in ("--password"):
      passwordflag = a
    if o in ("--encoding"):
      encoding = a
  message = ' '.join(args)
  if not message:
    PrintUsageAndExit()
  rc = TweetRc()
  username = usernameflag or GetUsernameEnv() or rc.GetUsername()
  password = passwordflag or GetPasswordEnv() or rc.GetPassword()
  if not username or not password:
    PrintUsageAndExit()
  api = twitter.Api(username=username, password=password, input_encoding=encoding)
  try:
    status = api.PostUpdate(message)
  except UnicodeDecodeError:
    print "Your message could not be encoded.  Perhaps it contains non-ASCII characters? "
    print "Try explicitly specifying the encoding with the --encoding flag"
    sys.exit(2)
  print "%s just posted: %s" % (status.user.name, status.text) 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:37,代碼來源:tweet.py

示例13: parse_options

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def parse_options(self, *args):
		'''Parse commandline options for this command
		Sets the attributes 'args' and 'opts' to a list of arguments
		and a dictionary of options respectively
		@param args: all remaining options to be parsed
		@raises GetOptError: when options are not correct
		'''
		options = ''
		long_options = []
		options_map = {}
		for l, s, desc in self.default_options + self.options:
			long_options.append(l)
			if s and l.endswith('='):
				options += s + ':'
				options_map[s] = l.strip('=')
			elif s:
				options += s
				options_map[s] = l

		optlist, args = gnu_getopt(args, options, long_options)
		self.args += args

		for o, a in optlist:
			key = o.strip('-')
			key = options_map.get(key, key)
			if a == '':
				self.opts[key] = True
			elif key in self.opts and isinstance(self.opts[key], list):
				self.opts[key].append(a)
			else:
				self.opts[key] = a 
開發者ID:zim-desktop-wiki,項目名稱:zim-desktop-wiki,代碼行數:33,代碼來源:command.py

示例14: main

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def main():
    scriptname = os.path.basename(sys.argv[0])

    try:
        long_opts = ['language=', 'help', 'usage']
        opts, args = getopt.gnu_getopt(sys.argv[1:], 'l:h', long_opts)
    except getopt.GetoptError:
        show_usage(scriptname)
        show_suggestion(scriptname)
        sys.exit(1)
    
    lang = 'english'

    for opt, arg in opts:
        if opt in ('-l', '--language'):
            lang = arg
        elif opt in ('-h', '--help'):
            show_help()
            return
        elif opt == '--usage':
            show_usage(scriptname)
            return

    # Tanl modules
    splitterModel = data + 'split/sentence/' + lang + '.punkt'
    if os.path.exists(splitterModel):
        print("No such model:" + splitterModel)
        return
    t0 = SentenceSplitter(splitterModel)
    t1 = Tokenizer()

    # Field containig tweets
    text_field = 3

    for line in sys.stdin:
        fields = line.split('\t')
        p0 = t0.pipe([fields[text_field]]) # SentenceSplitter
        p1 = t1.pipe(p0)                   # Tokenizer
        tokens = []
        for t in p1:
            form = t['FORM']
            if form != '\n':
                tokens.append(form)
        fields[text_field] = ' '.join(tokens)
        print('\t'.join(fields)) 
開發者ID:attardi,項目名稱:deepnl,代碼行數:47,代碼來源:tweet-tokenize.py

示例15: remove

# 需要導入模塊: import getopt [as 別名]
# 或者: from getopt import gnu_getopt [as 別名]
def remove(self, context, *names: commands.clean_content):
		"""Removes one or more emotes from the bot. You must own all of them.

		Optional arguments:
			-f, --force Whether to forcibly remove the emotes. This option can only be used by emote moderators.
		"""

		try:
			opts, names = getopt.gnu_getopt(names, 'f', ('force',))
		except getopt.GetoptError:
			opts = []
		opts = frozenset(dict(opts))

		force = False
		if '-f' in opts or '--force' in opts:
			if not await self.db.is_moderator(context.author.id):
				return await context.send(_('Error: only emote moderators may forcibly remove emotes.'))
			force = True

		logger = (
			(lambda emote: self.logger.on_emote_force_remove(emote, context.author))
			if force
			else self.logger.on_emote_remove)

		if not names:
			return await context.send(_('Error: you must provide the name of at least one emote to remove'))
		messages = {}

		async with context.typing():
			for name in names:
				arg = fr'\:{name}:'

				try:
					emote = await self.db.get_emote(name)
				except BaseException as error:  # XXX
					messages.setdefault(self._humanize_errors(error), []).append(arg)
					continue

				# log the emote removal *first* because if we were to do it afterwards,
				# the emote would not display (since it's already removed)
				removal_messages = await logger(emote)
				try:
					await self.db.remove_emote(emote, context.author.id, force=force)
				except (errors.ConnoisseurError, errors.DiscordError) as error:
					messages.setdefault(self._humanize_errors(error), []).append(arg)
					# undo the log
					await asyncio.gather(*map(operator.methodcaller('delete'), removal_messages), return_exceptions=True)
				else:
					message = _('**Successfully deleted:**')
					messages.setdefault((0, message), []).append(emote.escaped_name())

		messages = sorted(messages.items())
		message = self._format_errors(messages)
		await context.send(message) 
開發者ID:EmoteBot,項目名稱:EmoteCollector,代碼行數:56,代碼來源:emote.py


注:本文中的getopt.gnu_getopt方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。