# typer_demo.py
import typer
from pathlib import Path
from typing import Optional
from typing_extensions import Annotated app = typer.Typer(rich_markup_mode="rich")
config_app = typer.Typer()
file_app = typer.Typer()
app.add_typer(config_app, name="config", help="Configuration management")
app.add_typer(file_app, name="file", help="File operations") # Shared verbose option
def verbose_callback(value: bool):
if value:
typer.echo("Verbose mode enabled") # 新增 quiet_callback 函数
def quiet_callback(value: bool):
if value:
typer.echo("Quiet mode enabled") # 添加 -quiet 参数
@app.callback()
def main(
verbose: Annotated[
bool,
typer.Option("--verbose", "-v", callback=verbose_callback, help="Enable verbose mode")
] = False,
quiet: Annotated[
bool,
typer.Option("--quiet", "-q", callback=quiet_callback, help="Enable quiet mode")
] = False
):
pass @config_app.command("show")
def show_config(
key: Annotated[
Optional[str],
typer.Argument(show_default=False, help="Configuration key to show")
] = None
):
"""Display configuration values"""
# Implementation would load actual config
mock_config = {"user": "admin", "age": 30}
if key:
typer.echo(f"{key}: {mock_config.get(key, 'Not found')}")
else:
for k, v in mock_config.items():
typer.echo(f"{k}: {v}") @config_app.command("set")
def set_config(
key: Annotated[str, typer.Argument(help="Configuration key to set")],
value: Annotated[str, typer.Argument(help="Value to set")],
age: Annotated[
Optional[int],
typer.Option(min=0, max=150, help="Age validation example")
] = None
):
"""Set configuration values"""
# Implementation would save config
if age is not None:
typer.echo(f"Setting age to {age} with validation")
typer.secho(f"Set {key} = {value}", fg="green") @file_app.command("upload")
def upload_file(
path: Annotated[
Path,
typer.Argument(exists=True, file_okay=True, dir_okay=False,
readable=True, resolve_path=True,
help="File path to upload")
],
chunk_size: Annotated[
int,
typer.Option("--chunk", "-c", help="Chunk size in bytes",
rich_help_panel="Advanced Options")
] = 1024,
retries: Annotated[
int,
typer.Option("--retries", "-r", help="Number of retries",
rich_help_panel="Advanced Options")
] = 3
):
"""Upload a file to remote server"""
progress = typer.progressbar(length=100, label="Uploading")
for _ in progress:
# Simulate upload progress
pass
typer.secho(f"Uploaded {path} successfully!", bold=True) @file_app.command("download")
def download_file(
url: Annotated[str, typer.Argument(help="File URL to download")],
output: Annotated[
Path,
typer.Option("--output", "-o", help="Output path",
envvar="OUTPUT_DIR")
] = Path("downloads")
):
"""Download a file from URL"""
if not output.exists():
output.mkdir(parents=True)
typer.echo(f"Downloading {url} to {output}") if __name__ == "__main__":
app()

python的typer写cli脚本如此简单的更多相关文章

  1. python——复制目录结构小脚本

    引言 有个需要,需要把某个目录下的目录结构进行复制,不要文件,当目录结构很少的时候可以手工去建立,当目录结构复杂,目录层次很深,目录很多的时候,这个时候要是还是手动去建立的话,实在不是一种好的方法,弄 ...

  2. C#调用Python脚本的简单示例

    C#调用Python脚本的简单示例 分类:Python (2311)  (0)  举报  收藏 IronPython是一种在 .NET及 Mono上的 Python实现,由微软的 Jim Huguni ...

  3. Python+selenium测试环境成功搭建,简单控制浏览器(firefox)接下来,继续学习其他浏览器上的测试环境搭建;学习Python语言,利用Python语言来写测试用例。加油!!!

    Python+selenium测试环境成功搭建,简单控制浏览器(firefox)接下来,继续学习其他浏览器上的测试环境搭建:学习Python语言,利用Python语言来写测试用例.加油!!!

  4. ? 原创: 铲子哥 搜狗测试 今天 shell编程的时候,往往不会把所有功能都写在一个脚本中,这样不太好维护,需要多个脚本文件协同工作。那么问题来了,在一个脚本中怎么调用其他的脚本呢?有三种方式,分别是fork、source和exec。 1. fork 即通过sh 脚本名进行执行脚本的方式。下面通过一个简单的例子来讲解下它的特性。 创建father.sh,内容如下: #!/bin/bas

    ? 原创: 铲子哥 搜狗测试 今天 shell编程的时候,往往不会把所有功能都写在一个脚本中,这样不太好维护,需要多个脚本文件协同工作.那么问题来了,在一个脚本中怎么调用其他的脚本呢?有三种方式,分别 ...

  5. python用于web题里写解密脚本

    题源自bugku里的WEB3 选择选项让他停止,F12后出现如下代码,一看数字就知道是ASC: 复制出来,写pyhton脚本如下,在编译器里跑一下 s='KEY{J2sa42ahJK-HS11III} ...

  6. Python Telnet弱口令爆破脚本及遇到的错误与问题

    写得时候遇到了一个很大的问题,就是我在发送用户名,接受用户名就会一直卡住.然后等了好久后提示 recv ‘\r\nSession timed out.\r\n\r\nTelnet Server has ...

  7. 不要问我有多懒,写个脚本跑django

    写django的都知道,要跑起django测试环境,只需要 python manage.py runserver 就可以了,但是时间一长,就觉得敲这个命令太浪费时间了,而我又是个懒人. 同事用的是ct ...

  8. 用Python和Pygame写游戏-从入门到精通(py2exe篇)

    这次不是直接讲解下去,而是谈一下如何把我们写的游戏做成一个exe文件,这样一来,用户不需要安装python就可以玩了.扫清了游戏发布一大障碍啊! perl,python,java等编程语言,非常好用, ...

  9. 写一个脚本,自动启动tomcat

    我的服务器是使用tomcat的,时不时tomcat的进程会突然结束掉,不知道为什么,从日志上看也没有任何可疑之处,貌似就这样突然没了,接下来的日志都是重新启动tomcat之后打印的了.原因找不到,但要 ...

  10. 使用C#给Linux写Shell脚本(下篇)

    在上篇的<使用C#给Linux写Shell脚本>结尾中,我们留下了一个关于C#如何调用BashShell的问题.在文章发布之后,我留意到有读者留言推荐使用“Pash”(一款类PowerSh ...

随机推荐

  1. WPF 加载外部字体

    例如将字体放入d:/Fonts 文件夹.然后就可以通过类似 btn.FontFamily = new FontFamily("file:///d:/Fonts/#Ashley"); ...

  2. 前端(四)-jQuery

    1.jQuery的基本用法 1.1 jQuery引入 <script src="js/jquery-3.4.1.min.js" type="text/javascr ...

  3. IT系统架构的演化-copy

    前言 一个成熟的大型网站(如淘宝.天猫.腾讯等)的系统架构并不是一开始设计时就具备完整的高性能.高可用.高伸缩等特性的,它是随着用户量的增加,业务功能的扩展逐渐演变完善的,在这个过程中,开发模式.技术 ...

  4. 使用 docker 搭建 MySQL 主从同步/读写分离

    拉取 MySQL 容器镜像 docker pull mysql:5.7 这里我使用的是 5.7 版本,如果你想要拉取最新版本的镜像,可以使用: docker pull mysql:latest 下载完 ...

  5. biancheng-Spring Cloud Alibaba Seata

    随着业务的不断发展,单体架构已经无法满足我们的需求,分布式微服务架构逐渐成为大型互联网平台的首选,但所有使用分布式微服务架构的应用都必须面临一个十分棘手的问题,那就是"分布式事务" ...

  6. Cockpit pg walkthrough Intermediate

    nmap 发现两个 web站 80 和 9090 还有 22端口 dirsearch 发现80端口有login.php 登录界面 发现没有弱口令 测试sql注入 测试了一会发现密码 password= ...

  7. 搭建个人AI知识库:RAG与本地模型实践指南

    引言 你是否想过拥有一个私人订制的AI助手,能够随时为你提供最个性化的信息?本文将带你一步步搭建一个基于本地模型和RAG技术的个人知识库. 搭建本地模型 环境 os: archlinux 内存: 32 ...

  8. 天翼云亮相操作系统大会&openEuler Summit 2023,斩获多项大奖!

    近日,由开放原子开源基金会等主办,以"崛起数字时代 引领数智未来"为主题的操作系统大会&openEuler Summit 2023在北京举行.大会邀请院士.产业组织及全球开 ...

  9. 玩转云端 | 真实模拟,即压即测,天翼云息壤性能测试PTS实践大揭秘!

    满城春色惹人醉,恰是出游好时节. 伴随春暖花开,我国旅游市场快速升温,越来越多的人开始走出家门,去追寻久违的诗和远方.根据文化和旅游部数据中心近日测算,预计2023年,我国国内旅游人数约为45.5亿人 ...

  10. .Net Core报“‘GB2312‘ is not a supported encoding name. For information on defining a custom encod”的错误

    1.问题描述 在.Net Core中使用Encoding.GetEncoding("GB2312")报如下错误: System.ArgumentException:"'G ...