黑马程序员技术交流社区

标题: 【上海校区】Python3.8 新特性:f-strings调试 [打印本页]

作者: 梁强    时间: 2020-4-16 17:39
标题: 【上海校区】Python3.8 新特性:f-strings调试
f-strings调试
这是Python3.8新特性的第三篇,第一篇介绍了Python3.8 新特性:赋值表达式,第二篇是Python3.8 新特性:仅位置参数。这篇文章介绍f-strings调试功能。
f-strings 是Python3.6中的新特性,Python3.8 中 f-strings 开始支持“=”操作,主要作用是方便用于调试。它的语法是:f'{expr=}' 。
写Python代码,我大部分时候都会用 print 函数调试,因为简单方便,如pdb、pycharm的断点调试功能只在少数特殊场景下才会使用。使用print 函数有什么问题呢?
在代码很长的复杂场景,你可能要打印好几个值,例如:
[Python] 纯文本查看 复制代码
name1 = "zhang"
name2 = "li"
name3 = "wang"
print(name1)
print(name2)
print(name3)
输出:
[Python] 纯文本查看 复制代码
li
wang
从输出结果来看,我们不知道哪个值对应的是哪个变量,在代码行数少的时候还能通过看源代码分辨出来,如果代码量很长很长时,就很容易搞混,不知你有没有遇到过,反正我经常为了区分谁是谁,打印时要加奇形怪异的特殊字符。
当然,在 print 时直接把变量名字打印出来是最直白的。
[Python] 纯文本查看 复制代码
name1 = "zhang"
name2 = "li"
name3 = "wang"
print(f"name1={name1}")
print(f"name2={name2}")
print(f"name3={name3}")
输出:
[Python] 纯文本查看 复制代码
name1=zhang
name2=li
name3=wang
为了调试方便,python3.8在f-strings中可以使用等号“=”,打印出来时,等号左边就是变量的名字,右边是对应的值。
[Python] 纯文本查看 复制代码
name1 = "zhang"
name2 = "li"
name3 = "wang"
print(f"{name1=}")
print(f"{name2=}")
print(f"{name3=}")
输出:
[Python] 纯文本查看 复制代码
name1=zhang
name2=li
name3=wang
再举个例子:
[Python] 纯文本查看 复制代码
>>> now = datetime.datetime.now()
>>> print(f"{now.day=}")
now.day=21






欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2