苦练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. / + * 改造你项目里最混乱的函数签名,让同事惊呼"专业"!

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

相关推荐
RockHopper202520 小时前
一种认知孪生xLLM架构的原理说明
人工智能·llm·数字孪生·认知孪生
weixin1997010801620 小时前
哔哩哔哩 item_get_video - 获取视频详情接口对接全攻略:从入门到精通
人工智能·音视频
沛沛老爹20 小时前
Web开发者实战RAG评估:从指标到工程化验证体系
前端·人工智能·llm·agent·rag·评估
清水白石00820 小时前
《深入 Python 上下文管理器:contextlib.contextmanager 与类实现方式的底层差异全景解析》
开发语言·python
qq_2004650520 小时前
日益衰落的五常“礼、义、仁、智、信”,蒸蒸日上的五德“升、悟、净、正、合”
人工智能·起名大师·改名大师·姓名学大师·姓名学专家
程序员佳佳20 小时前
GPT-4时代终结?GPT-5.2与Banana Pro实测数据公开,普通开发者如何接住这泼天富贵
开发语言·python·gpt·chatgpt·重构·api·midjourney
Kiyra20 小时前
阿里云 OSS + STS:安全的文件上传方案
网络·人工智能·安全·阿里云·系统架构·云计算·json
程途拾光15820 小时前
自监督学习在无标签数据中的潜力释放
人工智能·学习
努力学算法的蒟蒻20 小时前
day46(12.27)——leetcode面试经典150
算法·leetcode·面试
墨染天姬21 小时前
【AI】5w/1h分析法
人工智能