如何使用 f“” 字符串而不是 .format() 打印二进制数?

要将一些数字打印为二进制格式,我们只需使用该.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


收到一只叮咚
浏览 238回答 2
2回答

心有法竹

这是我的看法:在旧.format()的 0 表示传递给格式函数的第一个元素。"{0:>2} in binary is {0:>08b}".format(i). 0 被使用两次来访问第一个变量两次。另一种写法是:"{:>2} in binary is {:>08b}".format(i,i)省略索引。在新f''格式中,我们改为传递变量/表达式。

牛魔王的故事

你的 f-string 应该有表达式而不是索引:f'{i:>2} in binary is {i:>08b}'0原始格式字符串中的任何地方都应替换为实际的第一个参数:在本例中为i.警告f 字符串中的表达式被计算两次,但是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被评估了多次,但这只是一个简单的参考。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python