我有一段代码如下:
builder.RegisterType<locationService>().AsImplementedInterfaces().InstancePerRequest()
因此,当以特定索引的所需格式打印上述元组时,我找到了这样的代码:
tupvalue = [('html', 96), ('css', 115), ('map', 82)]
我想知道格式说明符>>> '%s:%d' % tupvalue[0]
'html:96'
如何将单个值tupvalue[0]
识别为两个值的元组?请用文档参考解释这个机制。
如何使用理解来格式化所需格式的'%s:%d'
中的所有值,如所示示例中所示?
答案 0 :(得分:4)
首先,简单的问题是:
如何使用理解来格式化所需格式的
tupvalue
中的所有值,如所示示例中所示?
这是列表理解:['%s:%d' % t for t in tupvalue]
现在,更难的问题!
格式说明符
tupvalue[0]
如何将单个值'%s:%d'
识别为两个值的元组?
你的直觉,这里有点奇怪的事情是正确的。 元组是特殊的语言,用于字符串格式化。
>>> '%s:%d' % ('css', 115) # tuple is seen as two elements
'css:115'
>>> '%s:%d' % ['css', 115] # list is just seen as one object!
TypeError: not enough arguments for format string
百分比样式的字符串格式不能正确地进行鸭子类型化。所以,如果你真的想格式化一个元组,你必须将它包装在另一个元组中,与其他任何类型的对象不同:
>>> '%s' % []
'[]'
>>> '%s' % ((),)
'()'
>>> '%s' % ()
TypeError: not enough arguments for format string
文档的相关部分位于4.7.2. printf
-style String Formatting部分,其中提到了:
如果format需要单个参数,则值可以是单个非元组对象。否则,值必须是具有格式字符串
指定的项目数的元组
对元组的奇怪处理是文档该部分开头的注释中提到的一个怪癖,也是建议使用较新的字符串格式化方法str.format
的原因之一。
请注意,字符串格式的处理发生在运行时 †。您可以使用抽象语法树验证这一点:
>>> import ast
>>> ast.dump(ast.parse('"%s" % val'))
"Module(body=[Expr(value=BinOp(left=Str(s='%s'), op=Mod(), right=Name(id='val', ctx=Load())))])"
'%s' % val
解析'%s'
和val
上的二进制操作,其处理方式类似于str.__mod__(val)
,在CPython中是BINARY_MODULO
操作码。这意味着当str
收到的{sup> * 不正确时,通常最多可以val
类型决定该做什么,只有在表达式评估后才会出现} em>,即一旦解释器到达那条线。因此,val
是错误类型还是元素太少/太多并不重要 - 这是运行时错误,而不是语法错误。
† 除了在某些特殊情况下,CPython的窥孔优化器能够在编译时“常量折叠”它。
* 除非val
的类型为子类str
,否则type(val).__rmod__
should be能够控制结果。< /子>