13

为了将一些数字打印为二进制格式,我们只需使用该.format()方法,如下所示:

# Binary
for i in range(5+1):
    print("{0:>2} in binary is {0:>08b}".format(i))

0 in binary is 00000000
1 in binary is 00000001
2 in binary is 00000010
3 in binary is 00000011
4 in binary is 00000100
5 in binary is 00000101

以其他格式(十六进制和八进制)打印也是如此,只需将后面的大括号替换为我们要打印的数字即可。但是有没有办法使用新f""字符串来替换.format()命令?我知道这可能看起来微不足道,但我在使用新功能时遇到了这个问题,此外还f""使代码更短且更具可读性。

for i in range(5+1):
    print(f'{0:>2} in binary is {0:>08b}')
# This prints out just 0s
4

2 回答 2

23

你的 f-string 应该有表达式而不是索引:

f'{i:>2} in binary is {i:>08b}'

原始格式字符串中的任何0位置都应替换为实际的第一个参数:在这种情况下为i.

警告

f-string 中的表达式被计算两次,但是format当你通过索引访问它时,参数 to 只被计算一次。这对于更复杂的表达式很重要。例如:

"{0:>2} in binary is {0:>08b}".format(i + 10)

这里的加法i + 10只发生一次。另一方面

f"{i+10:>2} in binary is {i+10:>08b}"

加法两次,因为它相当于

"{:>2} in binary is {:>08b}".format(i + 10, i + 10)

或者

"{0:>2} in binary is {1:>08b}".format(i + 10, i + 10)

解决方法是预先计算多次出现在 f 字符串中的表达式的结果:

j = i + 10
f"{j:>2} in binary is {j:>08b}"

现在j被多次评估,但这只是一个简单的参考。

于 2018-10-17T08:17:29.653 回答
1

这是我的看法:

在旧.format()的 0 代表传递给格式函数的第一个元素。"{0:>2} in binary is {0:>08b}".format(i). 0 被使用两次来访问第一个变量两次。另一种写法是:"{:>2} in binary is {:>08b}".format(i,i)省略索引。

在新f''格式中,我们改为传递变量/表达式。

于 2018-10-17T08:40:53.530 回答