ai didi

python - Unpickle 使用 SQLAlchemy pickle 的元素 "by hand"

转载 作者:行者123 更新时间:2023-12-01 01:04:10 24 4
gpt4 key购买 nike

我有一个应用程序,可以将一些 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_pickle
session.add(db_object)
session.commit()

到目前为止,这有效。

上面提到的应用程序已经可以投入生产使用。我现在想做的是将其中一些数据库元素复制到我的 jupyter 笔记本中以进行操作和测试一些东西。

我的想法是手动将我的对象从数据库复制到 jupyter 中的 python 字符串中。我的数据库中的 pickle 字符串如下所示:

pickle_string = 0x800495FF020000000...5622E

当我没有尝试 unpickle 该字符串时,我收到 unpickling 堆栈下溢错误:

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 pickle 的元素复制到数据库中并在其他地方取消 pickle 。

最佳答案

0x800495FF020000..ET-SQL binary constant ,或者换句话说,SQL Server 显示二进制数据的方式。 Python 的 pickle另一方面期望bytes – 不是包含 T-SQL 二进制常量表示形式的字符串。在 unpickle 对象之前,您必须先转换表示形式:

# 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)

关于python - Unpickle 使用 SQLAlchemy pickle 的元素 "by hand",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55533906/

24 4 0
文章推荐: python - django-admin makemessages : how does it work with txt, xml 和其他文件?
文章推荐: emacs - 讽刺模式不选择包含路径
文章推荐: class - Arduino:用户自定义类型 "does not name a type"
文章推荐: google-bigquery - BigQuery 压缩响应
行者123
个人简介

我是一名优秀的程序员,十分优秀!

滴滴打车优惠券免费领取
滴滴打车优惠券
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com