我正在尝试使用SQLAlchemy + Python将一个项目添加到我的数据库中,但始终出现错误。
我的database_setup.py:
class company(Base):
__tablename__ = 'company'
compID = Column(Integer, primary_key = True)
name = Column(String(80), nullable = False)
class item(Base):
__tablename__ = 'items'
itemID = Column(Integer, primary_key = True)
name = Column(String(80), nullable = False)
category = Column(String(250))
description = Column(String(250))
price = Column(String(8))
compID = Column(Integer, ForeignKey('company.compID'))
company = relationship(company)
在将sqlalchemy导入到终端后,我定义了一个要插入的项目:
JawboneUP3 = item(
itemID="1",
name="Jawbone UP3",
description="The latest UP!",
category="tracker",
price="$174.99",
company="Jawbone"
)
并绘制一个会话以添加和提交:
session.add(JawboneUP3)
session.commit()
当我提交时,我不断收到此错误:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/session.py", line 1399, in add
self._save_or_update_state(state)
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/session.py", line 1417, in _save_or_update_state
halt_on=self._contains_state):
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/mapper.py", line 2037, in cascade_iterator
parent_dict, visited_states, halt_on))
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/properties.py", line 932, in cascade_iterator
get_all_pending(state, dict_)
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/attributes.py", line 761, in get_all_pending
ret = [(instance_state(current), current)]
AttributeError: 'str' object has no attribute '_sa_instance_state'
我在我的公司表中添加了一个“ Jawbone”对象,我理解我的“
JawboneUP3”应该与之相关。该对象是通过我通过网络服务器脚本启用的浏览器表单正确添加的。我相信我应该能够从终端直接添加项目。
我认为问题在于您如何定义相关的公司架构:
JawboneUP3 = item(itemID = "1", name = "Jawbone UP3", description = "The latest UP!",
category = "tracker", price = "$174.99", company = "Jawbone")
# HERE^
该item
构造函数需要一个company
实例,但你传递一个字符串值。修理它:
JawboneUP3 = item(itemID="1",
name="Jawbone UP3",
description="The latest UP!",
category="tracker",
price="$174.99",
company=company(name="Jawbone"))
问题内容: 为什么被认为是物体?返回列表中的第一项,但我不能追加到列表中的第一项。谢谢。 Edit01: @pyfunc:谢谢您的解释;现在我明白了。 我需要一个清单清单。因此“来自表单”应为列表。我做到了(如果这不是正确的方法,请更正): 问题答案: myList [1]是myList的元素,其类型是字符串。 myList [1]是str,您不能附加它。myList是一个列表,您应该已经附加了它
问题内容: 有点困惑,因为我很肯定我以前曾经做过这项工作。 我创建了以下方法… 但是当我在导入的CSV文件上运行它时,会产生此错误: 尽管我可以看到这是文档中的一个属性: https://pandas.pydata.org/pandas- docs/stable/generation/pandas.Series.str.isnumeric.html?highlight=isnumeric#pand
问题内容: 我正在尝试过滤出包含产品列表的数据框。但是,我遇到了熊猫-每当我运行代码时,“ dataframe”对象都没有属性“ str”错误。 这是代码行: 如果有人有任何建议的想法,请告诉我。我已经搜索了很多次,而且非常困惑。 产品是对象数据类型。 编辑: 这是头: 编辑2:这是print(data),A是产品。当我将其打印出来时,看起来好像A不在类别产品下。 问题答案: 答案很简单: 改变成
问题内容: 我在python 3.3.4中遇到“解码”方法的问题。这是我的代码: 但是我无法解码此问题的代码: 你有什么想法?谢谢 问题答案: 一种 编码 字符串,另一种 解码 字节。 您应该从文件中读取字节并对其进行解码: 幸运的是,有一个编码参数使操作变得简单:
问题内容: 这是我的代码: 此时,我收到错误消息 Python 3不再具有解码了,对吗?我怎样才能解决这个问题? 另外,在: 我只选择第一封电子邮件。如何选择全部? 问题答案: 您正在尝试解码 已解码 的对象。您有一个,不再需要从UTF-8解码。 只需删除部分: 至于您的通话,您明确要求仅发送第一条消息。如果要检索更多消息,请使用范围。请参阅文档: 下面命令的 message_set 选项是一个字