亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

編寫Python腳本把sqlAlchemy對(duì)象轉(zhuǎn)換成dict的教程

 更新時(shí)間:2015年05月29日 12:36:26   作者:wangdai  
這篇文章主要介紹了編寫Python腳本把sqlAlchemy對(duì)象轉(zhuǎn)換成dict的教程,主要是基于Python的model類構(gòu)建一個(gè)轉(zhuǎn)換的方法,需要的朋友可以參考下

在用sqlAlchemy寫web應(yīng)用的時(shí)候,經(jīng)常會(huì)用json進(jìn)行通信,跟json最接近的對(duì)象就是dict,有時(shí)候操作dict也會(huì)比操作ORM對(duì)象更為方便,畢竟不用管數(shù)據(jù)庫(kù)session的狀態(tài)了。

假設(shè)數(shù)據(jù)庫(kù)里有一張post表,其中一種方法就是

p = session.query(Post).first()
p.__dict__

但由于p是sqlAlchemy的對(duì)象,所以p.__dict__中會(huì)有一些其他的屬性比如_sa_instance這種我們不需要關(guān)注的

那么我們可以給model的基類加一個(gè)方法,假設(shè)models.py中原來(lái)是這樣

Base = sqlalchemy.ext.declarative.declarative_base()

class Post(Base):
  __tablename__ = 'post'
  id = Column(Integer, primary_key=True)
  title = Column(String)

那么我們可以加一個(gè)to_dict()方法到Base類中

def to_dict(self):
  return {c.name: getattr(self, c.name, None) for c in self.__table__.columns}

Base.to_dict = to_dict

這樣就可以

p = session.query(Post).first()
p.to_dict()

當(dāng)然,如果model沒(méi)有和table綁定的話model里是沒(méi)有__table__的信息的,可能也會(huì)出問(wèn)題,不過(guò)我目前覺(jué)得這樣最方便了

相關(guān)文章

  • 如何用OpenCV -python3實(shí)現(xiàn)視頻物體追蹤

    如何用OpenCV -python3實(shí)現(xiàn)視頻物體追蹤

    OpenCV是一個(gè)基于BSD許可(開(kāi)源)發(fā)行的跨平臺(tái)計(jì)算機(jī)視覺(jué)庫(kù),可以運(yùn)行在Linux、Windows、Android和Mac OS操作系統(tǒng)上。這篇文章主要介紹了如何用OpenCV -python3實(shí)現(xiàn)視頻物體追蹤,需要的朋友可以參考下
    2019-12-12
  • 淺談python浮點(diǎn)數(shù)比較的三種方法

    淺談python浮點(diǎn)數(shù)比較的三種方法

    在 Python 中,由于浮點(diǎn)數(shù)在計(jì)算機(jī)內(nèi)部的表示方式是二進(jìn)制的,因此進(jìn)行浮點(diǎn)數(shù)比較時(shí)可能會(huì)出現(xiàn)精度問(wèn)題,本文就介紹了三種解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • 使用python進(jìn)行圖片的文字識(shí)別詳細(xì)代碼

    使用python進(jìn)行圖片的文字識(shí)別詳細(xì)代碼

    Tesseract OCR是一款由Google團(tuán)隊(duì)開(kāi)發(fā)的開(kāi)源OCR引擎,用于將圖片、PDF 等格式中的文本轉(zhuǎn)換為可編輯的文本格式,本文主要介紹了Python進(jìn)行圖片的文字識(shí)別功能OCR的相關(guān)知識(shí),需要的朋友可以參考下
    2023-05-05
  • Python進(jìn)階多線程爬取網(wǎng)頁(yè)項(xiàng)目實(shí)戰(zhàn)

    Python進(jìn)階多線程爬取網(wǎng)頁(yè)項(xiàng)目實(shí)戰(zhàn)

    這篇文章主要為大家介紹了Python進(jìn)階,Python多線程爬取網(wǎng)頁(yè)項(xiàng)目實(shí)戰(zhàn)的示例呈現(xiàn)步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-10-10
  • Python 跨文件夾導(dǎo)入自定義包的實(shí)現(xiàn)

    Python 跨文件夾導(dǎo)入自定義包的實(shí)現(xiàn)

    有時(shí)我們自己編寫一些模塊時(shí),跨文件夾調(diào)用會(huì)出現(xiàn)ModuleNotFoundError: No module named 'XXX',本文就來(lái)介紹一下解決方法,感興趣的可以了解一下
    2023-11-11
  • 詳解Python3序列賦值、序列解包

    詳解Python3序列賦值、序列解包

    這篇文章主要介紹了Python3序列賦值、序列解包的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • python簡(jiǎn)易遠(yuǎn)程控制單線程版

    python簡(jiǎn)易遠(yuǎn)程控制單線程版

    這篇文章主要為大家詳細(xì)介紹了python簡(jiǎn)易遠(yuǎn)程控制單線程版,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • Python實(shí)現(xiàn)購(gòu)物車程序

    Python實(shí)現(xiàn)購(gòu)物車程序

    這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)購(gòu)物車程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • pycharm 創(chuàng)建py文件總是為txt格式的問(wèn)題及解決

    pycharm 創(chuàng)建py文件總是為txt格式的問(wèn)題及解決

    這篇文章主要介紹了pycharm 創(chuàng)建py文件總是為txt格式的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Pycharm內(nèi)置終端及遠(yuǎn)程SSH工具的使用教程圖文詳解

    Pycharm內(nèi)置終端及遠(yuǎn)程SSH工具的使用教程圖文詳解

    這篇文章主要介紹了Pycharm內(nèi)置終端及遠(yuǎn)程SSH工具的使用教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03

最新評(píng)論