不易损坏型

2024-10-02 18:23:44 发布

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

# all ingredients, represented by numbers: 0= empty selection 1=rice 2=spice 3=vegetable 
allIng = [0,1,2,3]

#Each individual recipe(r)


# Veggie Rice Balls
r1 = (0,1,3)

# Curry Rice
r2 =(0,1,2)

# Herb Sauté
r3 = (0,2,3)

# Vegetable Curry
r4 = (1,2,3)


# all recipes on one list 

allRec = [r1,r2,r3,r4]
allRecNames = {(0,1,3): 'Veggie Rice Balls', (0,1,2): 'Curry Rice', (0,2,3): 'Herb Sauté', (1,2,3): 'Vegetable Curry'}


#ingredients picked
iP = []
#ingredient count
iC = 1

#User given option to pick up to 3 ingredients
while iC <= 3:
    pitem = int (input ("Pick up to 3 items "))

    if pitem in allIng:
        iP.append(pitem)
        print(iP)
        iC += 1
    else:
        print ("Incorrect entry, please pick again")

#sort list
iP.sort()
iP = tuple(iP)

#compare iP to allRec looking for matches
if iP in allRec:

    match = set ([iP]) & set(allRec)
    print ("Match:",match)
    allRecNames[match]

大家好

试着让我的代码打印出与它们各自匹配的菜肴的名称。例如,如果我输入0,1,3,我会得到素食饭团

当前获取错误:TypeError:不可损坏的类型:“set”

如果我错了,请纠正我的错误和ELI5,但这是否意味着我需要将匹配项转换为可哈希的内容:

 allRecNames[match]

之前有人在我的代码中推荐了元组转换,并认为我也可以在这里做类似的事情,但没有得到任何线索和错误

和往常一样,如果这是一个愚蠢的帮助,任何帮助都是感激和抱歉的


Tags: toipmatch错误allprintsetic
2条回答

回答标题中的问题:在将其用作字典键之前,请尝试以下操作:

match = frozenset(match)

报告的错误意味着match是可修改的set,因此它不能用作字典键。通过使用frozenset我们使其不可变,因此我们可以将其用作密钥

但要注意,这不是真正的问题match看起来不包含您期望的值,该值可以用作allRecNames的键。我做了一个简单的例子,它看起来像这样:

match
=> set([(1, 2, 3)])

但是allRecNames中的键如下所示:

allRecNames.keys()
[(0, 1, 2), (0, 2, 3), (1, 2, 3), (0, 1, 3)]

你发现问题了吗?您的match变量包含一组元组列表,但是allRecNames的键只是一个元组。你的代码被设计破坏了——也许你真正真正的意思是:

if iP in allRec:
    allRecNames[iP]

字典中的键是元组,因此需要使用元组来访问它。幸运的是,iP是一个元组,您已经知道它是字典中的一个键,因为这是您的if语句测试的内容

所以,您只需要将allRecNames[match]更改为allRecNames[iP]

也就是说,这条线本身没有任何作用;它只从字典中获取一个值,但不将该值用于任何事情。您可能想要打印它,因此在这种情况下,它应该是print(allRecNames[iP])

相关问题 更多 >