为了账号安全,请及时绑定邮箱和手机立即绑定

使用 SQLAlchemy“手动”腌制的 Unpickle 元素

使用 SQLAlchemy“手动”腌制的 Unpickle 元素

繁星coding 2021-12-29 20:47:44
我有一个应用程序可以将一些 python 元素提取到数据库中。SQLAlchemyCode 如下所示:class DatabaseTable(base):    __tablename__ = 'TableName'    id = db.Column(Integer, primary_key=True, autoincrement=True)    pickeled_element_column = Column(sqlalchemy.types.PickleType, nullable=False)不,我可以将元素放入我的数据库中:db_object = DatabaseTable()db_object.pickeled_element_column = object_to_picklesession.add(db_object)session.commit()到目前为止,这是有效的。上面提到的应用程序已经投入生产使用。我现在想要做的是将其中一些数据库元素复制到我的 jupyter notebook 中以进行测试并测试一些东西。我的想法是将我的对象从数据库手动复制到 jupyter 中的 python 字符串中。我的数据库中的 pickle 字符串如下所示:pickle_string = 0x800495FF020000000...5622E当我不尝试解开该字符串时,我会收到一个解压堆栈下溢错误:pickle.loads(pickle_string.encode())---------------------------------------------------------------------------UnpicklingError                           Traceback (most recent call last)<ipython-input-508-58d250332c2d> in <module>()      1 pickeled_string = "0x800495FF020000..E"      2 ----> 3 pickle.loads(pickeled_string.encode())UnpicklingError: unpickling stack underflow所以最后这是我的问题。如何将 SQLAlchemy 腌制的元素复制到数据库中并在其他地方解压。
查看完整描述

1 回答

?
青春有我

TA贡献1784条经验 获得超8个赞

这0x800495FF020000..E是一个T-SQL 二进制常量,或者换句话说,SQL Server 显示二进制数据的方式。pickle另一方面,Python期望bytes– 不是包含 T-SQL 二进制常量表示的字符串。您必须先转换表示,然后才能解开对象:


# I'll assume you actually have the full binary string without the `..` truncation

binary_constant = "0x800495FF020000..E"

pickled_data = bytes.fromhex(binary_constant[2:])

obj = pickle.loads(pickled_data)

如果您仍在使用 Python 2(您应该迁移到 3),您似乎会得到它pickle.loads()接受字符串值,您将不得不使用一些不同的方法:


import binascii


binary_constant = "0x800495FF020000..E"

pickled_data = binascii.unhexlify(binary_constant[2:])

obj = pickle.loads(pickled_data)      


查看完整回答
反对 回复 2021-12-29
  • 1 回答
  • 0 关注
  • 210 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信