问题描述
我作为初学者学习 Python。最近学习了格式化方法,字典等。目前正在学习for循环,发现了一个函数叫enumerate(可能和问题无关)。我通过混合所有东西来应用我到目前为止学到的知识。突然我发现两种格式方法的行为不同!!这是如何以及为什么发生的?请解释。
方法一:
nameAgeDictionary = {'Jack': 38,'John': 51,'Alex': 13,'Alvin': 'Not Available'}
for index,name in enumerate(nameAgeDictionary):
print('(%d) Name = %s,Age = %s' % (index+1,name,nameAgeDictionary[name])) # Format_Method_1
输出:
(1) 姓名 = 杰克,年龄 = 38
(2) 姓名 = 约翰,年龄 = 51
(3) 姓名 = Alex,年龄 = 13
(4) 姓名 = Alvin,年龄 = 不可用
方法二:
nameAgeDictionary = {'Jack': 38,name in enumerate(nameAgeDictionary):
print('({0:d}) Name = {1:s},Age = {2:s}'.format(index+1,nameAgeDictionary[name])) # Format_Method_2
输出:
回溯(最近一次调用最后一次): 文件“PATH_to_File.py”,第 3 行,
print('({0:d}) Name = {1:s},Age = {2:s}'.format(
ValueError: UnkNown format code 's' for type 'int' 对象
我尝试将 d 放在 s 的位置,在这种情况下,它会打印前 3 行并卡在最后一行(例如不可用)。
解决方法
由于年龄的类型是混合的(str
和int
),所以不要指定类型。
for index,name in enumerate(nameAgeDictionary):
print('({0:d}) Name = {1:s},Age = {2}'.format(index+1,name,nameAgeDictionary[name])) # Format_Method_2
通过执行此操作,应调用输入的 __str__
,从而将 int
安全地转换为 str
。结果是:
(1) Name = Jack,Age = 38
(2) Name = John,Age = 51
(3) Name = Alex,Age = 13
(4) Name = Alvin,Age = Not Available
我假设(但我不完全确定)与 .format()
相比,%
格式调用 __str__
作为后备。
更新
以下是 %
格式化调用 __str__
的证据:
class test():
def __str__(self):
return 'bar'
foo = test()
print('%s'%(foo))
印刷品
bar