我有一个代表扑克牌的字符串列表。等级可以是
A23456789TJQK
这是我的清单
# L2
['5', '6', '7', 'A', 'K']
我正在尝试使用有序函数中的键调用函数来按顺序返回卡等级数值。所以这是我的功能:
def sortYo():
myDict = {'A': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9, 'T': 10, 'J': 10, 'Q': 10, 'K': 10}
这是我的电话:
L4 = sorted(L2, key = sortYo())
但是我的L4也是如此:
# L4
['5', '6', '7', 'A', 'K']
为什么我的sortYo()函数没有改变值?提前谢谢。
编辑:
from collections import Counter
from itertools import combinations
import sys
myList = sys.argv
myList.pop(0)
Suits = ['H', 'S', 'D', 'C']
Nums = ['A', '2', '3', '4', '5', '6', '7', '8', '9', 'T', 'J', 'Q', 'K']
SuitsTwo = {'♥': 'H', '♦': 'D', '♣': 'C', '♠': 'S'}
print(myList)
L1 = [] # Suits
L2 = [] # Ranks
L3 = [i for i in myList[0]] # Cut
for i in myList:
for x in i:
if x in SuitsTwo:
L1.append(SuitsTwo[x])
elif x in Suits:
L1.append(x)
else:
L2.append(x)
print('L1:'
print(L1)
print('L2:')
print(L2)
print('L3:')
print(L3)
score = 0
# straight
sC = 0
myDict = {'A': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9\
': 9, 'T': 10, 'J': 10, 'Q': 10, 'K': 10}
L4 = sorted(L2, key = lambda x: myDict.get(x,11))
print('L4')
print(L4)
#RUN
python3 as13.py AS 5H 6C 7S KH
['AS', '5H', '6C', '7S', 'KH']
L1:
['S', 'H', 'C', 'S', 'H']
L2:
['A', '5', '6', '7', 'K']
L3:
['A', 'S']
L4
['A', '5', '6', '7', 'K']
0
答案 0 :(得分:3)
尝试使用lambda函数作为排序键:
myDict = {'A': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8,
'9': 9, 'T': 10, 'J': 10, 'Q': 10, 'K': 10}
L4 = sorted(L2, key=lambda x: myDict.get(x, 11))
这将按myDict
中与每个键相关联的值排序。它还会在排序列表末尾的L2
键中放置myDict
中的任何值,方法是将默认值11
分配给未知密钥。
如果您不必担心L2
中不在myDict
键内的项目,您也可以使用:
L4 = sorted(L2, key=myDict.get)