Redian新闻
>
Python 命令补全工具 argcomplete

Python 命令补全工具 argcomplete

公众号新闻

1. 概述

在使用Python 命令或者 Python的命令行工具的时候,一个痛点是没有补全。比如python -m后面输入包名字,就没有提示,每次想运行一个http server的时候,都需要搜索一下http服务的包名。另外,像pip,pipx等命令也没有提示,使用不太方便。

偶然看到argcomplete[1]这个库,按tab键就可以给Python的命令行添加自动补全,简直是使用Python的一个神器。

具体来说,argcomplete有下面的特点:

  • 官方支持支持bash和zsh两种shell,对tcsh和fish有第三方贡献者提供的支持(不好意思Windows用户这里又被当做二等公民了 )
  • 可以对python命令和pip命令进行补全
  • 其他任何以argparse解析的第三方包的命令都可以用自动补全,添加argcomplete的几行代码就行

下面具体展开怎么对已有的工具启用自动补全,以及如何让自己的Python包支持argcomplete。

2. 对Python和pip启用自动补全

首先通过pip命令来安装argcomplete:

pip install argcomplete

然后执行下面的语句来启用对Python和pip的自动补全:

activate-global-python-argcomplete

重启Shell,试试输入pip然后按tab,发现就会列出所有的命令选项。

3. 如何对别的第三方库启用自动补全

有些库的命令行程序是已经支持argcomplete补全,只需要用下面的命令来激活:

eval "$(register-python-argcomplete <python-app-name>)"

例如 pipx 包安装后会在系统安装一个命令行程序pipx,且pipx已经支持argcomplete,我们就可以用下面的命令来激活自动补全:

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

激活后输入pipx in 按tab键,就可以列出pipx所有以in开头的命令,再按tab键会在各个候选命令之间切换。

⚠️注意:这个激活命令是只对哪些代码中已经支持了argcomplete语句的程序才生效,如果代码中无这些语句,那是不生效的。

4. 如何让自己的Python库支持自动补全

只需要增加下面几行代码,就能让你的库的命令行支持自动补全:

# 在ArgumentParser对象初始化前增加这两行
# PYTHON_ARGCOMPLETE_OK
import argcomplete, argparse

# 原有代码
parser = argparse.ArgumentParser()
...

# 在调用parse_args()函数前增加这一行
argcomplete.autocomplete(parser)

# 原有代码
args = parser.parse_args()
...

然后你的包安装后,对应的命令行程序就可以用eval "$(register-python-argcomplete )"来补全了。

⚠️注意:如果程序执行到argcomplete.autocomplete() 被调用的地方耗时很久的话,用户按tab就会有明显的延迟感。所以尽量将一些比较耗时的操作放在argcomplete.autocomplete() 语句后面,比如一些import语句,常常比较耗时,可以往后放。

希望这个程序能让你的Python开发变得舒服一些。

链接:https://juejin.cn/post/7242676843987124279

(版权归原作者所有,侵删)


微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
我曾和一个赤裸的男人共同生活上下文1.6万token的编程大模型来了!与Stable Diffusion出自同门,一次吃5个Python文件不费劲使用这些 Python 工具可视化地探索数据 | Linux 中国Python 之父“摇人”来搞掉 GIL,Meta 果断出手LLVM&Swift之父宣布全新AI开发编程语言"Mojo",兼容Python,且快35000倍政策的蝴蝶翅膀Stable家族上新!全新编码工具StableCode,16000上下文,5个Python文件同编辑LPython:最新的高性能Python实现、速度极快且支持多后端免费试听|全面掌握Python, SQL等数据分析语言、工具和拓展包,高效斩获心仪offer!Python那些优质可视化工具!Hurun China Metaverse Companies with the Greatest Potential 2023#英语学习#Finish和Complete有什么区别?看看你能答对这道题吗?详解Python文件: .py、.ipynb、.pyi、.pyc、​.pyd !一些 Python 代码加速工具!比Python快3.5万倍的Mojo融资7亿,LLVM之父:不会威胁到Python,该恐惧的应该是C++VS Code内置JS减小20%;Python团队官宣下线GIL;Chrome替代品1.0发布;Twitter改名X | 周热点To Stop Teen From Moving, Chongqing Mom Flees With School Papers比Python快35000倍!LLVM&Swift之父宣布全新编程语言Mojo:编程被颠覆了Corsair DOMINATOR PLATINUM RGB 32GB 5600MHz DDR5, White scorptec福克斯让卡尔森走人的背后Python重量级证书!Meta官方盖章:7天拿证,留学生零门槛旧学比 GitHub Copilot 更强大?Meta 开源 AI 编码工具,能跨多语言补全和调试代码Excel最新版官方支持Python,打工人的工具又强化了Python 吞噬世界,GPT 吞噬 Python!ChatGPT 上线最强应用:分析数据、生成代码都精通Erklärung zur ZusammenarbeitLPython:最新的高性能 Python 实现、速度极快且支持多后端Python 吞噬世界,GPT 吞噬 Python!ChatGPT 上线最强应用CompletableFuture真香,可以替代CountDownLatch!比 Python 快 3.5 万倍的 Mojo 融资七亿,LLVM之父:不会威胁到 Python,该恐惧的应该是 C++Target 超市:买 $100 Apple 礼卡获赠 $10 Target 礼卡【又有了,9/2 截止】Python之父“摇人”来搞掉GIL,Meta果断出手Python吞噬世界,GPT吞噬Python!ChatGPT 上线最强应用:分析数据、生成代码都精通“母公司”不是mother company,“子公司”更不是son company!历史小说《黄裳元吉》第八十七章 悲苦
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。