inspect python模块_Python标准库inspect的具体使用方法

inspect模块用于收集python对象的信息,可以获取类或函数的参数的信息,源码,解析堆栈,对对象进行类型检查等等,有几个好用的方法:

Doc:这样写到

The inspect module provides several useful functions to help get information about live objects such as modules,classes,methods,functions,tracebacks,frame objects,and code objects.

这个模块是针对模块,类,方法,功能等对象提供些有用的方法。

getargspec(func)

返回一个命名元组ArgSpect(args,varargs,keywords,defaults),args是函数位置参数名列表,varargs是*参数名,keywords是**参数名,defaults是默认参数值的元组。

在用__init__参数自动初始化实例属性的实践中,是用字节码对象的co_varnames属性来获取函数的位置参数名的:

def attr_from_locals(locals_dict):

self = locals_dict.pop('self')

code = self.__init__.__func__.__code__

args = code.co_varnames[1:code.co_argcount]

for k in args:

setattr(self,k,locals_dict[k])

class Foo(object):

def __init__(self,name,color,num=1):

x = 1

attr_from_locals(locals())

而当__init__方法使用**特殊参数接收任意数量的关键字参数时,上述代码是不适用的。可行的办法是使用字节码的co_flags属性来判断**参数是否存在。

函数使用*args语法来接受任意数量的位置参数时,co_flags置位0x04,使用**kwargs语法时,置位0x08,函数为一个生成器时,置位0x2000,其它位保留:

>>> def foo(x,*args,**kwargv):

pass

>>> foo.__code__.co_varnames

('x','args','kwargv')

>>> foo.__code__.co_flags & 0x04

4

>>> foo.__code__.co_flags & 0x08

8

inspect模块的getargspec()方法正是用此判断来获取函数的特殊参数的。现在可以方便的获取__init__的**参数了:

import inspect

def attr_from_locals(locals_dict):

self = locals_dict.pop('self')

args = inspect.getargspec(self.__init__.__func__).args[1:]

for k in args:

setattr(self,locals_dict[k])

keywords = inspect.getargspec(self.__init__.__func__).keywords

if keywords:

keywords_dict = locals_dict[keywords]

for k in keywords_dict:

setattr(self,keywords_dict[k])

class Foo(object):

def __init__(self,**kwargv):

attr_from_locals(locals())

f = Foo('bar',color='yellow',num=1)

print f.__dict__

结果为:

{'color': 'yellow','num': 1,'name': 'bar'}

对象已经正确的初始化了。

getmembers(object[,predicate])

返回一个包含对象的所有成员的(name,value)列表。返回的内容比对象的__dict__包含的内容多,源码是通过dir()实现的。

predicate是一个可选的函数参数,被此函数判断为True的成员才被返回。

getmodule(object)

返回定义对象的模块

getsource(object)

返回对象的源代码

getsourcelines(object)

返回一个元组,元组第一项为对象源代码行的列表,第二项是第一行源代码的行号

ismodule,isclass,ismethod,isfunction,isbuiltin

一系列判断对象类型的方法,大都是包装了isinstance(object,types.FunctionType)之类语句的函数。

现在可以用类型判断来返回一个类的方法了:

class Foo(object):

'''Foo doc'''

def __init__(self,name):

self.__name = name

def getname(self):

return self.__name

inspect.getmembers(Foo,inspect.ismethod)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

相关文章

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中,缩进是非常重要的,它用于表示代码块的层次结构。Python并没有强制要求使用Tab缩进或者空格缩进,但是绝对不能混用Tab空格。根据PEP8规范,建议使用4个空格作为缩进\[1\]。在Python 3中,空格是首选的缩进方法,一般使用4个空格表示一级缩进\[2\]。如果在代码中混合使用Tab空格,可能会导致语法错误。 关于浮点型数据,Python中的浮点型占用8个字节(64位),遵守IEEE标准\[3\]。浮点型的取值范围为-1.8e308到1.8e308,超出这个范围的值会被视为无穷大(inf)或无穷小(-inf)\[3\]。因此,在进行浮点数计算时,需要注意范围限制和精度问题。 #### 引用[.reference_title] - *1* [空格还是Tab?用Vim写Python缩进的正确姿势](https://blog.csdn.net/weixin_39941262/article/details/110830198)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [第二章 Python基础](https://blog.csdn.net/xiaoma1245379/article/details/121983023)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值