字符串是如何比较的?
问题描述
我想知道Python如何进行字符串比较,更具体地说,当使用小于<
或大于>
运算符时,它如何确定结果。
print('abc' < 'bac')
放入True
,则得到True
。我知道它比较字符串中的相应字符,但不清楚为什么会有更多字符,因为没有更好的术语,";weight";放在第一个字符串中的a
小于b
(第一个位置),而不是第二个字符串(第二个位置)中的a
小于b
。
解决方案
来自docs:
比较使用词典编纂 订购:先订购前两件商品 是比较的,如果它们不同的话 确定 比较;如果它们相等,则 接下来的两个项目进行比较,因此 打开,直到任一序列 筋疲力尽。
同时:
字符串的字典序排序使用Unicode码位编号对单个字符进行排序。
或在Python 2上:
字符串的词典编排顺序对单个字符使用ASCII排序。
举例:
>>> 'abc' > 'bac' False >>> ord('a'), ord('b') (97, 98)
发现
a
小于b
,立即返回结果False
。不比较其他项目(如您看到的第二个项目:b
>a
isTrue
)。注意大小写:
>>> [(x, ord(x)) for x in abc] [('a', 97), ('b', 98), ('c', 99), ('d', 100), ('e', 101), ('f', 102), ('g', 103), ('h', 104), ('i', 105), ('j', 106), ('k', 107), ('l', 108), ('m', 109), ('n', 110), ('o', 111), ('p', 112), ('q', 113), ('r', 114), ('s', 115), ('t', 116), ('u', 117), ('v', 118), ('w', 119), ('x', 120), ('y', 121), ('z', 122)] >>> [(x, ord(x)) for x in abc.upper()] [('A', 65), ('B', 66), ('C', 67), ('D', 68), ('E', 69), ('F', 70), ('G', 71), ('H', 72), ('I', 73), ('J', 74), ('K', 75), ('L', 76), ('M', 77), ('N', 78), ('O', 79), ('P', 80), ('Q', 81), ('R', 82), ('S', 83), ('T', 84), ('U', 85), ('V', 86), ('W', 87), ('X', 88), ('Y', 89), ('Z', 90)]
相关文章