python中dump函数_python中实现php的var_dump函数功能

最近在做python的web开发(原谅我的多变,好东西总想都学着。。。node.js也是),不过过程中总遇到些问题,不管是web.py还是django,开发起来确实没用php方便,毕竟存在的时间比较短,很多不完善的地方。

比如我在调试php中最常用的函数,var_dump,在python里找不到合适的替代函数。php中var_dump是一个特别有用的函数,它可以输出任何变量的值,不管你是一个对象还是一个数组,或者只是一个数。它总能用友好的方式输出,我调试的时候经常会需要看某位置的变量信息,调用它就很方便:

但是开发python的时候就没有太好的替代方案。

之前想到repr,但这个函数只是调用了对象中的__str__,和直接print obj没啥区别。print是打印它,而repr是将其作为值返回。如果对象所属的类没有定义__str__这个函数,那么返回的就会是难看的一串字符。

后来又想到了vars 函数,vars函数是python的内建函数,专门用来输出一个对象的内部信息。但这个对象所属的类中必须有__dict__函数。一般的类都有这个dict,但像[]和{}等对象就不存在这个dict,这样调用vars函数就会抛出一个异常:

Traceback (most recent call last):

File "", line 1, in

TypeError: vars() argument must have __dict__ attribute

所以后来几经寻找,找到一个个比较好,功能能够与var_dump类似的函数如下:

def dump(obj):

'''return a printable representation of an object for debugging'''

newobj=obj

if '__dict__' in dir(obj):

newobj=obj.__dict__

if ' object at ' in str(obj) and not newobj.has_key('__type__'):

newobj['__type__']=str(obj)

for attr in newobj:

newobj[attr]=dump(newobj[attr])

return newobj

这是使用方式:

class stdClass(object): pass

obj=stdClass()

obj.int=1

obj.tup=(1,2,3,4)

obj.dict={'a':1,'b':2, 'c':3, 'more':{'z':26,'y':25}}

obj.list=[1,2,3,'a','b','c',[1,2,3,4]]

obj.subObj=stdClass()

obj.subObj.value='foobar'

from pprint import pprint

pprint(dump(obj))

最后输出是:

{'__type__': '<__main__.stdclass object at>',

'dict': {'a': 1, 'c': 3, 'b': 2, 'more': {'y': 25, 'z': 26}},

'int': 1,

'list': [1, 2, 3, 'a', 'b', 'c', [1, 2, 3, 4]],

'subObj': {'__type__': '<__main__.stdclass object at>',

'value': 'foobar'},

'tup': (1, 2, 3, 4)}

然后github有个开源的module,可以参考:https://github.com/sha256/python-var-dump

说一下pprint这个函数,他是一个人性化输出的函数,会将要输出的内容用程序员喜欢的方式输出在屏幕上。参阅这篇文章比较好理解://www.zyiz.net/article/60143.htm

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/246451.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

查询去重_【Freya的MySQL课堂】DQL基础查询

MYSQL基础查询各位小伙伴们晚上好&#xff0c;今天是10月22号。我是你们的Freya。今天我们开始学习MySQL中的DQL语言。Do Not Stop Learning我的小课堂我爱学习&#xff0c;学习使我快乐今天你学习了吗&#xff1f;一、语法select 查询列表from 表名;二、特点1、查询列表可以是…

二阶偏微分方程组 龙格库塔法_有限单元法(Finite Element Method)实现声波方程模拟(Part 2)...

2.1 前言承接上一篇文章&#xff0c;前面我们已经介绍了一维声波方程有限元求解&#xff1a;蓝不是蓝&#xff1a;有限单元法(Finite Element Method)实现声波方程模拟&#xff08;Part 1&#xff09;​zhuanlan.zhihu.com这一部分将一维问题提升到二维问题。不知道大家有没有发…

mysql时间排序_mysql – 按日期和时间降序排序?

所有我想显示最近5个输入的数据&#xff0c;以获取特定的ID。我的sql查询是&#xff0c;SELECT id, name, form_id, DATE(updated_at) as dateFROM wp_frm_itemsWHERE user_id 11 && form_id9ORDER BY updated_at DESCupdated_at是DATETIME它按日期显示最后5个条目&am…

python图片转文字_【收藏】图片转成文字的方法总结,python批量图片转文字信息参考源码...

在日常办公或者学习中&#xff0c;往往存在这样一个工作场景&#xff0c;比如&#xff0c;“老王&#xff0c;我这里有一张图片&#xff0c;你把里面的文字信息给我整理出来”&#xff0c;都2021年了&#xff0c;你真的还在手敲图片文字信息么&#xff1f;那么还不赶紧收藏这篇…

mysql 写磁盘_图解MySQL | [原理解析] MySQL insert 语句的磁盘写入之旅

作者及简介&#xff1a;黄 炎&#xff0c;爱可生首席技术官&#xff1b;王 悦&#xff0c;爱可生研发团队成员&#xff0c;负责数据库管理平台相关项目的开发和故障排查&#xff0c;好奇 MySQL 技术原理及各类数据库实现方案。本文来源&#xff1a;转载自公众号-图解 MySQL*爱可…

监控mysql主从复制监控_shell脚本监控mysql主从同步状态

mysql做了主从同步之后&#xff0c;偶尔出现过几次主从同步报错或延迟&#xff0c;由于没有任何监控和报警机制&#xff0c;只有在应用程序报错的时候才能发现数据同步出问题了。所以写了个shell脚本用来检测mysql数据库的同步状态#!/bin/bash#monitor_mysql_slave statusUSERN…

apscheduler mysql_APScheduler (重点)

定时校正需求: mysql和redis两个系统, mysql增加数据成功, redis未必添加成功, 这样两个系统的数据可能出现偏差, 所以需要定期对mysql和redis的数据进行同步解决方案: 每天执行一次定时任务, 让mysql数据和redis数据进行同步crontab是linux系统一个内置命令, 依赖于linux系统,…

qpsk 锁相环_本科毕业设计课题—QPSK相干解调的MATLAB仿真(4)

继续看参考资料&#xff01;现在常用的数字调制方式有二相移相键控(BPSK)、正交移相键控(QPSK)、偏移四项移相键控(OQPSK)、最小移频键控(MSK)等。它们具有相同的功率效率。BPSK 频谱利用率差&#xff0c;抗非线性能力差&#xff0c;实现简单&#xff1b;QPSK频谱利用率好&…

c语言程序后退_c语言中向后退一格是啥符号?

展开全部是 \b&#xff0c;也就是backspace&#xff0c;这是一个转义32313133353236313431303231363533e4b893e5b19e31333337393466字符&#xff0c;详解如下&#xff1a;所有的ASCII码都可以用“\”加数字(一般是8进制数字)来表示。而C中定义了一些字母前加"\"来表示…

mysql数据库行业应用_腾讯云发布MySQL 8.0数据库 可应用至更多行业场景

7月8日&#xff0c;腾讯云正式发布了MySQL 8.0数据库。据悉&#xff0c;该数据库相比MySQL官方版本&#xff0c;无论是单机模式、异步模式还是同步模式下&#xff0c;读写性能都取得了大幅提升。据腾讯云数据库相关负责人介绍&#xff0c;采用MySQL 8.0内核的实例最高QPS(每秒查…

中控ecs700 mysql_浙大中控ECS700工程指导手册.pdf

浙大中控ECS700工程指导手册VisualFieldWARNING: Indicates information that a potentially hazardous situation which, if not avoided,could result in serious injury or death.Risk of electrical shock: Indicates information that Potential shock hazard whereHAZARD…

postgresql是如何求年龄的_Postgresql 通过出生日期获取年龄的操作

三个基础的时间表示函数 current_date/current_time/now()select current_date ;返回当前日期以 年-月-日(yyyy-mm-dd)的形式&#xff1a;2019-01-10select current_time;返回当日时间以 时:分:秒时区(hh:mm:ss )的形式&#xff1a;17:49:11.58530808select now();返回当前时间…

python关闭浏览器删除session_Django操作session 的方法

session是存放在服务端的&#xff0c;在django中使用session必须要先在数据库中创建django_session表&#xff0c;session相关信息都要依赖此表获取sessionrequest.session[status]request.session.get(status)#一般用get&#xff0c;无此键返回None不报错设置session#在使用se…

python压缩文件不带根路径_python 压缩文件(解决压缩路径问题)

#压缩文件def Zip_files(): datapath filepath# 证据路径file_newname datapath .zip# 压缩文件的名字log.debug(file_newname) z zipfile.ZipFile(file_newname,w,zipfile.ZIP_DEFLATED) for dirpath,dirmanes,filenames in os.walk(datapath): fpath dirpath.replace(da…

python网页保存为图片_使用Python保存网页上的图片或者保存页面为截图

Python保存网页图片这个是个比较简单的例子&#xff0c;网页中的图片地址都是使用http://。。。。.jpg这种方式直接定义的。使用前&#xff0c;可以先建立好一个文件夹用于保存图片&#xff0c;本例子中使用的文件夹是 d:\\pythonPath这个文件夹代码如下&#xff1a;# -*- codi…

libnss mysql_Ubuntu通过LDAP集成AD域账号登录(libnss-ldap方式)

Ubuntu通过LDAP集成AD域账号登录(libnss-ldap方式)&#xff1a;# apt-get install libnss-ldap (中间直接回车&#xff0c;忽略)# vi /etc/nsswitch.confpasswd: files ldapgroup: files ldapshadow: files ldap:wq# vi /etc/ldap.confbase dcming,dccomuri ldap://10.0.0.2…

mysql分页查询减轻压力_mysql分页查询优化

在实际的项目中&#xff0c;分页查询是在寻常不过的&#xff0c;甚至说不可避免的。通常数据量较少的时候&#xff0c;很难遇到效率的影响。但是当数据量较大时&#xff0c;一个普通的分页sql能让你恶心到家。我们常用的分页sql如下&#xff1a;1 SELECT * FROM table_name LIM…

python csv读写方法_python中csv文件的若干读写方法小结

如下所示&#xff1a; //用普通文本文件方式打开和操作with open("file.csv") as cf:linescf.readlines()...... //用普通文本方式打开&#xff0c;用csv模块操作import csvwith open("file.csv") as cf:linescsv.reader(cf)for line in lines:print(line)…

unity 世界坐标间角度_Unity 世界坐标局部坐标下的旋转

一、旋转方法在 Unity 中为物体旋转提供了各种 API &#xff0c;例如 RotateAround、Rotate、LookAt 等方法。但为了避免万向节死锁的问题&#xff0c;一般使用四元数来表示物体的旋转。四元数的乘法可以看作对一个物体施加两次旋转&#xff0c;最终的旋转角度由这两次旋转的角…

删除mysql会不会留下痕迹_MySQL使用痕迹清理~/.mysql_history

mysql会给出咱们最近执行的SQL命令和脚本&#xff1b;同linux command保存在~/.bash_history同样&#xff0c;你用mysql链接MySQL server的全部操做也会被记录到~/.mysql_history文件中&#xff0c;这样就会有很大的安全风险了&#xff0c;如添加MySQL用户的sql也一样会被明文记…