
在3.0之前的Python版本中,有两种字符串:“普通字符串”和“
unipre字符串”。普通字符串(
str)不能表示拉丁字母之外的字符(为简单起见,忽略代码页的详细信息)。Unipre字符串(
unipre)可以代表任何字母的字符,包括虚构的字母,例如Klingon。
那么,为什么要使用两种字符串,仅使用Unipre会更好,因为这将涵盖所有情况?最好只使用Unipre,但是在Unipre是表示字符串的首选方法之前创建了Python。在具有许多用户的语言中转换字符串类型需要花费时间,在Python
3.0中最终所有字符串都是Unipre。
3.0版之前的Python字符串的继承层次结构为:
object | | basestring / / str unipre
可以将Python 2.3中引入的’basestring’视为朝着字符串统一方向迈出的一步,因为它可用于检查对象是否为
str或的实例。
unipre
>>> string1 = "I am a plain string">>> string2 = u"I am a unipre string">>> isinstance(string1, str)True>>> isinstance(string2, str)False>>> isinstance(string1, unipre)False>>> isinstance(string2, unipre)True>>> isinstance(string1, basestring)True>>> isinstance(string2, basestring)True
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)