python中的列表/元组排序问题

2024-09-29 17:17:12 发布

您现在位置:Python中文网/ 问答频道 /正文

我是一个编程新手,我正在创建一个配对程序,来比较我用列表存储的个性分数,下面是我的代码:

`ps = int(personality_score)
potential_partners = partners.Partners()
while potential_partners.available():
partner = []
personality_scores = []
a = potential_partners.get_name()
f = int(potential_partners.get_personality_score())
if ps == f:
print("This is your match" + a)
else:
g = abs(int(ps - f))
h = int(g)
personality_scores.append(h)
partner.append(a)
partner_compatability =list(zip(personality_scores, partner))
partner_compatability.sort(key = operator.itemgetter(0))
for sub in partner_compatability:
print(sub)`        

我查看了多个与此相关的问题和答案,没有一个对我有效,我从列表中得到的结果是:

`[['Mary Smith', 1]]
[['Juan Lopez', 5]]
[['Leslie Liu', 11]]
[['Tatiana Ivanov', 15]]
[['Andre Leroy', 11]]
[['Sam Augusta', 7]]
[['Adalbert Weber', 1]]`

但应该从最低分到最高分排序:

`[['Mary Smith', 1]] 
[['Adalbert Weber', 1]]
[['Juan Lopez', 5]]
[['Sam Augusta', 7]]
[['Leslie Liu', 11]]
[['Andre Leroy', 11]]
[['Tatiana Ivanov', 15]]`

Tags: 列表partnergetintpspotentialscoresmith
3条回答
import operator

data = [
    ['Mary Smith', 1],
    ['Juan Lopez', 5],
    ['Leslie Liu', 11],
    ['Tatiana Ivanov', 15],
    ['Andre Leroy', 11],
    ['Sam Augusta', 7],
    ['Adalbert Weber', 1],
]

data.sort(key = operator.itemgetter(1))
for sub in data:
    print(sub)

印刷品

['Mary Smith', 1]
['Adalbert Weber', 1]
['Juan Lopez', 5]
['Sam Augusta', 7]
['Leslie Liu', 11]
['Andre Leroy', 11]
['Tatiana Ivanov', 15]

虽然不是很清楚,但是操作符函数应该比等价的lambda快。还有attrgetter。当键应该是多个项的元组时,两者都可以使用。你知道吗

您可以直接对partner_compatability进行排序

sorted_list = partner_compatability.sort(key=lambda x: x[1])

我试着这样做,因为没有提供列表值

In [67]: a
Out[67]: [8, 9, 3]
In [68]: b
Out[68]: [5, 6, 3]

In [69]: partner_compatability = list(zip(a, b))

In [70]: partner_compatability
Out[70]: [(8, 5), (9, 6), (3, 3)]

In [71]: partner_compatability.sort(key=lambda x: x[1])
In [72]: partner_compatability
Out[72]: [(3, 3), (8, 5), (9, 6)]

从你的评论来看

partner_compatability = [[(1, 'Mary Smith')],
 [(5, 'Juan Lopez')],
 [(11, 'Leslie Liu')],
 [(15, 'Tatiana Ivanov')],
 [(11, 'Andre Leroy')],
 [(7, 'Sam Augusta')],
 [(1, 'Adalbert Weber')]]

partner_compatability.sort(key=lambda x: x[0][0])

In [71]: partner_compatability
Out[71]:
[[(1, 'Mary Smith')],
 [(1, 'Adalbert Weber')],
 [(5, 'Juan Lopez')],
 [(7, 'Sam Augusta')],
 [(11, 'Leslie Liu')],
 [(11, 'Andre Leroy')],
 [(15, 'Tatiana Ivanov')]]

(我也是一个新手程序员,直到有更好的答案)你可以做我做的:只要颠倒顺序,然后排序。你知道吗

lst = [['Mary Smith', 1],
['Juan Lopez', 5],
['Leslie Liu', 11],
['Tatiana Ivanov', 15],
['Andre Leroy', 11],
['Sam Augusta', 7],
['Adalbert Weber', 1]]

然后:

sorted_lst = [[k,v] for v,k in lst]
sorted_lst.sort()
print(sorted_lst)

相关问题 更多 >

    热门问题