亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

使用 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 關注
  • 244 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號