苦练Python第33天:斜杠 / 与星号 * 的魔法——彻底搞懂函数参数顺序

前言

大家好,我是倔强青铜三 。欢迎关注我,微信公众号:倔强青铜三。欢迎点赞、收藏、关注,一键三连!!!

欢迎来到苦练Python第33天

今天,我们把显微镜对准 Python 函数定义里两个不起眼的符号:/*。它们看似低调,却掌控着位置参数关键字参数的生死大权。五分钟读完,包你不再写出一团浆糊的函数签名。


📌 为什么要用 /*

  • 在 Python 3.8 之前,想限定"只能按位置传"或"只能按关键字传"得靠约定。
  • 从 3.8 起,/* 被正式写入语法,强制隔离参数种类,提升可读性、兼容性与安全性。

1️⃣ / ------ 左侧仅限位置参数

✅ 语法

python 复制代码
def demo(a, b, /, c):
    ...
  • 位于 / 左侧ab 只能按位置传值。
  • 位于 / 右侧c 不受限制,可位置也可关键字。

🧪 实战示例

python 复制代码
def greet(name, age, /, city):
    print(f"{name} is {age} years old, from {city}.")

# ✅ 合法调用
greet("Alice", 30, "New York")
greet("Alice", 30, city="New York")

# ❌ 非法调用
greet(name="Alice", age=30, city="New York")
# TypeError: greet() got some positional-only arguments passed as keyword arguments

2️⃣ * ------ 右侧仅限关键字参数

✅ 语法

python 复制代码
def demo(*, x, y):
    ...
  • 位于 * 右侧xy 只能按关键字传值。
  • 位于 * 左侧的参数不受限制。

🧪 实战示例

python 复制代码
def divide(a, *, b):
    return a / b

# ✅ 合法调用
divide(10, b=2)

# ❌ 非法调用
divide(10, 2)
# TypeError: divide() takes 1 positional argument but 2 were given

3️⃣ /* 同台竞技------全排列组合

✅ 终极模板

python 复制代码
def full(a, b, /, c, d, *, e, f):
    ...
参数 传递方式
a, b 仅位置
c, d 位置或关键字
e, f 仅关键字

🧪 实战示例

python 复制代码
def create_user(id, name, /, age, city=None, *, vip=False):
    print(id, name, age, city, vip)

# ✅ 合法调用
create_user(1001, "Tom", 18)
create_user(1001, "Tom", 18, city="Shanghai")
create_user(1001, "Tom", 18, city="Shanghai", vip=True)

# ❌ 非法调用
create_user(id=1001, name="Tom", age=18)
# TypeError: create_user() got some positional-only arguments passed as keyword arguments

4️⃣ 常见误区与最佳实践

误区 正确姿势
/* 顺序写反 只能 / 在前 * 在后
想让所有参数都可关键字 不写 /
想让所有参数都可位置 不写 *

🧠 速记口诀

"斜杠左位,星右关键;斜星同框,顺序莫乱。"


🎯 今日练习

  1. 写一个 move(x, y, /, step=1, *, direction) 函数,只允许 xy 按位置传,direction 必须关键字传。
  2. / + * 改造你项目里最混乱的函数签名,让同事惊呼"专业"!

最后感谢阅读!欢迎关注我,微信公众号倔强青铜三。欢迎点赞收藏关注,一键三连!!!

相关推荐
康斯坦丁师傅16 分钟前
发现一个插件,免费用谷歌最新NanoBanana 2
人工智能
用户114818678948434 分钟前
Vite项目中的SVG雪碧图
前端·面试
emo猫pro_max2 小时前
openclaw飞书流式回复配置指南
人工智能
FishCoderh2 小时前
被OpenClaw的Session搞晕了?这篇让你彻底搞懂
人工智能
孤烟2 小时前
19 万 + GitHub 星标!OpenClaw 凭什么成为 2026 最火 AI Agent,万字实测告诉你
人工智能
晴殇i3 小时前
CommonJS 与 ES6 模块引入的区别详解
前端·javascript·面试
zhl773 小时前
YOLOv5:从0搭建你的第一个目标检测模型
人工智能
TechFind3 小时前
用 OpenClaw 搭建企业微信 AI Agent:从零到自动化客服只需 30 分钟
人工智能·agent
FishCoderh3 小时前
OpenClaw部署后Tools工具权限被禁用?一行配置解决
人工智能
青青家的小灰灰3 小时前
金三银四面试官最想听的 React 答案:虚拟 DOM、Hooks 陷阱与大型列表优化
前端·react.js·面试