Python3 初学实践案例(10)对象转字典 object to dict

Python3 初学实践案例(10)对象转字典 object to dict

我在写代码的时候遇到一个问题,就是 sqlalchemy 从数据库中查的的结果是一个对象,我虽然可以直接把这个对象用 x.id 的方式取出来内容,但是总是感觉不爽,我希望可以更好的处理这个对象。但是打印出来的结果一直是 <__main__.Passwd object at 0x10ea50cc0> 这样的东西。

通过查看文档,我找到了一个函数 vars(obj) 。这个函数可以把对象转换成字典。文档地址:https://docs.python.org/3/library/functions.html?highlight=vars#vars

但是输出的结果是这样的:

{'_sa_instance_state': <sqlalchemy.orm.state.InstanceState object at 0x10e773cf8>, 'name': 'sunmingyuan', 'id': 2, 'password': '/t22664Q44', 'time': datetime.datetime(2017, 12, 20, 5, 11, 22)}

虽然这个结果已经可以让我使用了,但是感觉还是怪怪的对么。所以,我接着搜索,终于找到了一个手写的函数,可以很好的处理这个问题:

def row2dict(row):
    d = {}
    for column in row.__table__.columns:
        d[column.name] = str(getattr(row, column.name))

    return d

用这个函数处理的结果就非常优雅了。

{'id': '17', 'name': 'love', 'password': 'xxxxx', 'time': '2017-12-22 05:08:27'}

参考地址:https://stackoverflow.com/questions/1958219/convert-sqlalchemy-row-object-to-python-dict

本文由 FungLeo 原创,允许转载,但转载必须保留首发链接。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值