Python脚本参数接收_sys与argparse解析【指导】
技术百科
舞夢輝影
发布时间:2026-01-01
浏览: 次 sys.argv适合简单场景,argparse更适合正式项目;前者仅提供原始参数列表,需手动解析和校验,后者支持自动帮助、类型检查、默认值及子命令等高级功能。
Python脚本接收命令行参数,sys.argv适合简单场景,argparse更适合正式项目——它自动处理帮助信息、类型校验、参数组合和错误提示。
用 sys.argv 快速获取原始参数
sys.argv 是一个列表,argv[0] 是脚本名,后续元素是传入的字符串参数。它不解析结构,也不做类型转换,适合写一次性小工具或调试时快速取值。
- 直接访问索引即可:比如
python script.py input.txt -v中,sys.argv[1]是"input.txt",sys.argv[2]是"-v" - 需手动判断参数是否存在、是否符合预期格式,否则容易触发
IndexError或类型错误 - 不支持
--、默认值、选项分组等特性,也不校验参数合法性
help
用 argparse 规范化定义和解析参数
argparse 是 Python 标准库中推荐的参数解析模块,适用于需要可维护性、可读性和用户友好性的脚本。
- 声明式定义参数:用
add_argument()明确指定名称、类型(type=int)、是否必需(required=True)、默认值(default="log.txt")等 - 自动支持短选项(
-f)、长选项(--file)、位置参数、可选参数、互斥组(add_mutually_exclusive_group()) - 调用
parser.parse_args()后返回命名空间对象,属性名即参数名(如args.input),无需索引操作 - 输入
--help或参数错误时,自动输出清晰的帮助文本,无需额外编码
常见搭配与实用技巧
实际使用中,常结合两者优势或补充功能:
- 位置参数 + 可选参数混合:例如
python convert.py source.json --output target.yaml --format yaml - 支持子命令:用
add_subparsers()实现类似git commit、git push的多模式脚本 - 从配置文件或环境变量回退:
argparse解析后,可用os.getenv()或configparser做兜底 - 自定义类型函数:传入
type=valid_date,在解析阶段就校验日期格式并抛出易懂错误
什么时候该选哪个?
判断依据主要是脚本用途和协作需求:
- 单人临时脚本、测试用例、CI 中简单调用 →
sys.argv足够轻量 - 要交付给他人、需文档化、可能频繁更新参数、涉及多个选项组合 → 必须用
argparse - 已有老脚本用
sys.argv,但开始出现if len(sys.argv) 这类硬编码判断 → 是重构为argparse的明确信号
# python
# 配置文件
# 工具
# js
# json
# 环境变量
# 编码
# 标准库
# git
# red
# python脚本
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Win11更新后变慢怎么办_Win11系统更新后卡
- Win11怎么关闭自动维护 Win11禁用系统自动
- 如何使用Golang安装依赖库_管理模块和第三方包
- LINUX如何开放防火墙端口_Linux fire
- c++中如何使用std::variant_c++1
- 如何在Golang中实现WebSocket广播_使
- Windows10蓝屏代码DPC_WATCHDOG
- Windows10蓝屏SYSTEM_SERVICE
- Win11如何设置系统语言_Win11系统语言切换
- Win11怎么关闭边缘滑动手势_Windows11
- Win11怎么更改管理员名字 Win11修改账户名
- Win10 BitLocker加密教程 Win10
- Win11相机打不开提示错误怎么修_相机权限开启与
- C++如何使用std::transform批量处理
- Win10任务栏天气和资讯怎么关闭 Win10禁用
- Win11摄像头无法使用怎么办_Win11相机隐私
- php订单日志怎么记录物流_php记录订单物流变更
- Python生成器表达式内存优化_惰性计算说明【指
- 如何使用正则表达式批量替换重复的星号-短横模式为固
- Windows10如何重置此电脑_Windows1
- Windows如何拦截2345弹窗广告_Windo
- php嵌入式多设备通信怎么实现_php同时管理多个
- Win11如何设置系统声音_Win11系统声音调整
- 如何优化Golang内存分配与GC调度_Golan
- VSC怎么在PHP中调试MySQL_数据库交互排查
- Win11怎么更改任务栏颜色_Windows11个
- Win11怎么更改盘符_Win11磁盘管理修改驱动
- Win11怎么关闭搜索历史_Win11清除设备上的
- Windows蓝屏BAD_POOL_HEADER故
- Go 中 := 短变量声明的类型推导机制详解
- Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱
- Win11怎样安装搜狗输入法_Win11安装搜狗输
- mac怎么分屏_MAC双屏显示与分屏操作技巧【指南
- C++中的Pimpl idiom是什么,有什么好处
- Win11怎么恢复出厂设置_Win11重置此电脑保
- php怎么下载安装后测试是否成功_简单脚本验证方法
- 如何在Golang中实现邮件发送功能_Golang
- C++如何使用std::async进行异步编程?(
- 如何在 Python 测试中动态配置 @backo
- Linux怎么禁止Root用户远程登录_Linux
- Win10系统映像怎么恢复 Win10使用系统映像
- 为什么Go建议使用error接口作为错误返回_Go
- Windows10如何更改日期格式_Win10区域
- Windows 10怎么隐藏特定更新补丁_Wind
- Win11怎么设置任务栏透明_Windows11使
- php本地部署后数据库连接报错_1045acces
- Windows 11如何查看系统激活密钥_Wind
- Windows7怎么找回经典开始菜单_Window
- Windows10系统怎么查看CPU温度_Win1
- php485函数怎么捕获异常_php485错误处理

help
QQ客服