TypeError:“系列”对象是可变的,因此无法将其散列以进行修改并将excel文件转换为数据框

如何解决TypeError:“系列”对象是可变的,因此无法将其散列以进行修改并将excel文件转换为数据框

import pandas as pd
import itertools
data = pd.read_excel("Kitchen.xlsx")
dict_data={}
for i in range(data.shape[0]):
   if(data["Yes_No"][i]=="yes"):
       if(data["Menu"] in dict_data.keys()):
           dict_data[data["Menu"][i]].append(data["Specification"][i])
       else:
           dict_data[data["Menu"][i]]=list(data["Specification"][i])
menu=pd.read_csv("Menu.csv")
menu["Menu"]=""
for i in range(menu.shape[0]):
   name=menu["Name"][i]
   comb=list(FC["Combinations"][i].split("+"))
   l=[]
   for c in comb:
       l.append(dict_data[c])
   all_combinations=list(itertools.product(*l))
   for men_cmb in all_combinations:
       s=""
       for item in men_cmb:
           s+=str(item)+"||"
       menu["Menu"][i]=s
       i+=1
menu.to_csv("Menu.csv")

我想打印菜单的配料组合。这是我第一次使用itertools,所以我真的不知道该错误意味着什么。我基本上想打印所有可能的组合来制作具有不同成分的菜单。 Menu.csv是我的最后一个强项,但在Kitchen.xls中,我有配料。

这是输出

C:\VEpython\Scripts\Drivers\Scripts>C:/Users/212803155/AppData/Local/Programs/Python/python38-32/python.exe "c:/VEpython/Scripts/Drivers/Scripts/import pandas as pd.py"
Traceback (most recent call last):
  File "c:/VEpython/Scripts/Drivers/Scripts/import pandas as pd.py",line 7,in <module>
    if(data["Menu"] in dict_data.keys()):
  File "C:\Users\212803155\AppData\Local\Programs\Python\python38-32\lib\site-packages\pandas\core\generic.py",line 1798,in __hash__
    raise TypeError(
TypeError: 'Series' objects are mutable,thus they cannot be hashed

C:\VEpython\Scripts\Drivers\Scripts>

解决方法

您的错误更根本,并且与itertools不相关:可变类型除非提供hash方法,否则是不可哈希的!

这也发生在简单类型上,但错误更明显。

>>> set().add({'a':1})
Traceback (most recent call last):
  File "<stdin>",line 1,in <module>
TypeError: unhashable type: 'dict'

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?