释放“用手”用SQLAlchemy腌制的元素

时间:2019-04-05 10:57:41

标签: python sql-server sqlalchemy pickle

我有一个将某些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_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 个答案:

答案 0 :(得分:2)

0x800495FF020000..ET-SQL binary constant,即SQL Server显示二进制数据的方式。另一方面,Python的pickle期望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)