python argparse中的自定义选项卡补全



如何在Python脚本中与argparse配合使用shell选项卡完成?

#!/usr/bin/env python
import argparse
def main(**args):
    pass
if __name__ == '__main__':
    parser = argparse.ArgumentParser()
    parser.add_argument('positional', choices=['spam', 'eggs'])
    parser.add_argument('--optional', choices=['foo1', 'foo2', 'bar'])
    args = parser.parse_args()
    main(**vars(args))

在.py文件上设置可执行标志后,预期结果应如下所示:

$ ./example.py sp<tab>             
   ->  completes to "./example.py spam"
$ ./example.py --op<tab> 
   ->  completes to "./example.py --optional"
$ ./example.py --optional b<tab>
   ->  completes to "./example.py --optional bar"
$ ./example.py --optional f<tab>   
   ->  completes to "./example.py --optional foo"
       and, additionally, prints  "foo1  foo2"  choices on stdout on a new line

看看 Andrey Kislyuk 的 argcomplete。

安装它:

pip install argcomplete

导入模块并在调用parser.parse_args()之前在源代码中添加一行:

#!/usr/bin/env python
import argparse as ap
import argcomplete
def main(**args):
  pass
if __name__ == '__main__':
  parser = ap.ArgumentParser()
  parser.add_argument('positional', choices=['spam', 'eggs'])
  parser.add_argument('--optional', choices=['foo1', 'foo2', 'bar'])
  argcomplete.autocomplete(parser)
  args = parser.parse_args()
  main(**vars(args))

为了确保 Bash 知道这个脚本,您可以使用

eval "$(register-python-argcomplete your_script)"

您应该将该行放在~/.bashrc或遵循 Argcomplete 的文档并激活"全局"完成。

之后,您可以按要求完成工作。

其工作方式是 eval 行创建一个函数_python_argcomlete该函数使用 complete 注册。(运行register-python-argcomplete your_script只是看看什么被评估成 bash)。自动完成函数查找由 bash 完成机制设置的环境变量,以查看它是否需要执行操作。如果它起作用,它将退出程序。如果它不起作用,这是对程序的正常调用,该函数不执行任何操作,程序的正常流继续。

要使

自动完成正常工作,您需要一个 bash 函数来生成可能的选项,然后您需要运行complete -F <function_name> <program_name>

最好的方法是让程序根据自己的解析算法生成完成函数,以避免重复。但是,快速浏览一下argparse,我找不到访问其内部结构的方法,但我建议您查找它。

这是一个 bash 函数,它将用于上述程序:

function _example_auto() {
    local cur=${COMP_WORDS[COMP_CWORD]}
    local prev=${COMP_WORDS[COMP_CWORD-1]}
    case "$prev" in
    --optional ) 
        COMPREPLY=( $(compgen -W "foo1 foo2 bar" -- $cur) )
        return 0
        ;;
    *)
        COMPREPLY=( $(compgen -W "--optional spam eggs" -- $cur) )
        return 0
        ;;
    esac
}

相关内容

  • 没有找到相关文章

最新更新