网站首页 > 编程文章 正文
在使用Flask-SQLAlchemy时,经常需要直接用sql语句,或有时需要Join联合多表查询,此时返回的结果SQLAlchemy不会自动转换为dict类型,而是内部使用的Row或RowProxy类型,在对这些数据进行Json转换,或返回给前端处理时系统会报错:
File "C:\Python\lib\json\encoder.py", line 179, in default
raise TypeError(f'Object of type {o.__class__.__name__} '
TypeError: Object of type Row is not JSON serializable
一、原因
由于直接使用sql特别是join多个表时,系统无法使用model定义的表对象表结果自动进行转换,而是直接返回Row对象的List,这个象的数据如下图所示:
二、解决方法
我在网上找了很长时间,没有找到直接可用的函数或解决方,只能对数据结构进行研究,自己写了一个把Row List转换为Dict List的方法,具体如 代码:
# 进接读取数据库,或者多表读取时,返回的是RowList,需要把row list转换为dict list
def row_to_dict(row_list):
result = []
for row in row_list:
row_value = {}
for field in row.keys():
data = row[field]
if isinstance(data, datetime.datetime):
data = data.strftime("%Y-%m-%d %H:%M:%S")
elif isinstance(data, datetime.date):
data = data.strftime('%Y-%m-%d')
elif isinstance(data, datetime.time):
data = data.isoformat()
elif isinstance(data, decimal.Decimal):
data = float(data)
row_value.update({field: data})
result.append(row_value)
return result
三、SQLAlchemy多表查询实现
下面是多表而查询实现代码:
if stock_code: # 多表查询不能用标准的query,返回的结果因为不是model中的对像,不能自己处理为标准的dct,需要将Row对象转为dict
stocks_score = StocksScoreGr.query.with_entities(StocksScoreGr.security_code, StocksScoreGr.scores,
StockBasic.security_name_abbr, StocksScoreGr.fx_date). \
filter(StocksScoreGr.security_code == stock_code).join(StockBasic,StocksScoreGr.security_code ==
StockBasic.security_code) \
.order_by(StocksScoreGr.scores.desc()).paginate(page, pagesize)
result = row_to_dict(stocks_score.items)
res = {'page': stocks_score.page, 'pages': stocks_score.pages, 'data': json.dumps(result)}
猜你喜欢
- 2025-04-02 震撼揭秘!如何用最佳实践保护你的 Docker 容器
- 2025-04-02 [常用工具] Python视频处理库VidGear使用指北
- 2025-04-02 SVM 算法 和 梅尔倒谱系数 结合使用噪音检测的应用
- 2025-04-02 5分钟掌握Python(十三)之元类(python 元类的作用)
- 2025-04-02 Python 字典l转换成 JSON(python 字典转换为json)
- 2025-04-02 Python推导式(python 列表推导)
- 2025-04-02 Python学习路上的10大难点,掌握它们你就是高手!
- 2025-04-02 什么是Python中的DSL领域特定语言?
- 2025-04-02 Python 数据的 JSON 格式序列化及反序列化
- 2025-04-02 22-4-Python高级特性-元类-描述符-练习
你 发表评论:
欢迎- 05-142014年最流行前端开发框架对比评测
- 05-14七爪源码:如何使用 Next.js 构建 Shopify 店面
- 05-14Web 前端怎样入门?
- 05-14我为什么不建议你使用框架
- 05-14推荐几个好用的React UI 框架
- 05-14PDFsharp:强大的 .NET 跨平台 PDF 处理库
- 05-14一组开源免费的Web动画图标,荐给需要的设计师和程序员
- 05-14salesforce 零基础学习(二十九)Record Types简单介绍
- 最近发表
- 标签列表
-
- spire.doc (59)
- system.data.oracleclient (61)
- 按键小精灵源码提取 (66)
- pyqt5designer教程 (65)
- 联想刷bios工具 (66)
- c#源码 (64)
- graphics.h头文件 (62)
- mysqldump下载 (66)
- sqljdbc4.jar下载 (56)
- libmp3lame (60)
- maven3.3.9 (63)
- 二调符号库 (57)
- 苹果ios字体下载 (56)
- git.exe下载 (68)
- diskgenius_winpe (72)
- pythoncrc16 (57)
- solidworks宏文件下载 (59)
- qt帮助文档中文版 (73)
- satacontroller (66)
- hgcad (64)
- bootimg.exe (69)
- android-gif-drawable (62)
- axure9元件库免费下载 (57)
- libmysqlclient.so.18 (58)
- springbootdemo (64)
本文暂时没有评论,来添加一个吧(●'◡'●)