首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python不等式运算符;比较列表

Python不等式运算符;比较列表
EN

Stack Overflow用户
提问于 2015-06-21 11:47:13
回答 3查看 3.9K关注 0票数 5

在使用不等式运算符比较列表时,难以理解Python行为。下面是一个使用python3命令行解释器的片段:

代码语言:javascript
复制
>>> [8] < [7]
False
>>> [8] < [9]
True
>>> [8, 6] < [9]
True
>>> [8, 6] < [9, 7]     
True                    # So far so good
>>> [8, 6] < [9, 5]     
True                    # Huh?

因此,显然Python不仅仅是在遍历并行索引。我确实找到了一些信息,在这个场景中,Python按“词汇学”顺序排列列表,我猜这是按字母顺序排列的。

所以,我想也许列表会被排序,然后通过并行方式进行比较,但是下面的例子证明了这一点:

代码语言:javascript
复制
>>> [1, 2, 3] < [3, 2, 1]
True

我猜内部比较应该是1,2,3< 1,2,3,这应该是假的,因为1<1是假的,2<2是假的,等等。

任何帮助都是非常感谢的。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-06-21 11:51:11

其实这很有道理。

这种比较类似于按字典顺序对单词进行排序。毕竟,单词也是列表:字符列表。

首先考虑第一项。如果一个较小,整个序列较小,如果它们相等,则移到第二个项,以此类推。

很明显,"86“在"95”之前,正如"az“放在"bc”之前,"100“排在"90”之前。

更多的这里

票数 2
EN

Stack Overflow用户

发布于 2015-06-21 11:56:54

Python所做的就是,并行地检查列表并比较相同索引的元素。当它第一次遇到不相等的元素时,它会返回这个结果。

这和比较词语是一样的:

代码语言:javascript
复制
"Peter" > "Peer"

前两个字母是相同的,第三个字母是不同的,并给出了结果。这(用于列表)与纸质词典中使用的技术相同,只是使用列表元素而不是字符。

附加信息:(正如所建议的):当一个列表更短,所有元素的大小都相同时,更长的列表被认为是更大的。这也与正常(纸张)词典中的情况相同。

票数 4
EN

Stack Overflow用户

发布于 2015-06-21 11:50:36

很明显,Python不仅仅是通过并行索引

是的,当它第一次找到不相等的值时,它就停止了。这确实是词典编纂的顺序。用字母替换示例中的数字,用字符串替换列表:

代码语言:javascript
复制
"h" < "g" # False
"h" < "i" # True
"hf" < "i" # True
"hf" < "ig" # True
"hf" < "ie" # True - not huh, hf does come before ie alphabetically.
"abc" < "cba" # True
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30964157

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档