python_反射

本文深入讲解了Python中的反射机制,包括如何使用__import__、getattr、hasattr、setattr及delattr等函数通过字符串形式操作模块及函数。同时,还介绍了这些技术在Web应用中的实际应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、反射:

作用与内存不影响原文件

通过字符串的形式,导入模块

通过字符串德的形式,去模块中寻找指定函数 (getattr)

通过 字符串的形式去判断某个模块的东西(hasattr)

通过字符串的形式去某个模块创建东西(setattr)

通过字符串去某个模块删除东西(delattr)

__import__(str,fromlist = True):fromlist 默认 为Flase ,当想到入多级时候True

import  datetime
#声明函数
im = input("请输入导入的函数")
#调用__import__  函数数将字符转换成对应的py文件
#等价于 import datatime as dd
dd = __import__(im)
print(dd.datetime.now())

f=getattr(object, name, default=None)

''''
default:当没有 函数的时候返回 None
object:导入的模块
name:函数,根据字符中的名字寻找模块中函数
f:指向函数是地址,调用f()
'''
二、getattr

#应用:根据用户输入的内容,导入模块
inp = input("请输入模块:")
print(inp,type(inp))
#
dd = __import__(inp) # import 文件名 as dd
inp_func = input("请输入要执行的函数")
#getattr 用于以字符串的形式去某个模块中寻找函数
target_func=getattr(dd,inp_func)#相当于import ti  ti.f()
#ti.f()
target_func()

>>>
请输入模块:ti
ti <class 'str'>
请输入要执行的函数f
1

三、hasatter

import ti
double_func = hasattr(ti,"f")
print(double_func)
>>> True  或者 Flase  看实际情况

四、setattr/delattr

import ti
#z相当于属性/穿入lambda 表达式相当于传进函数
double_func = setattr(ti,"z",lambda a:a+b)

del_func = delattr(ti,"f")

五、根据反射理解web
#模块名/函数名
url = input("请输入url")
target_module,target_func = url.split("/")
#login.文件名/target_module模块名/fromlist同意引入模块名
m = __import__("login."+target_module,fromlist=True)
#指向文件的对应方法
if hasattr(m,target_func):
    f= getattr(m,target_func)
    f()
else:
    print("404")





### Python 中 `__class__` 的用法与含义 在 Python 中,`__class__` 是一个特殊属性,用于访问某个对象所属的类。它是一个内置机制,允许开发者通过实例获取其对应的类定义[^1]。 #### 属性说明 对于任何由类创建的对象,都可以通过 `. __class__` 访问该对象的类本身。这不仅适用于普通的用户自定义类,也适用于内置类型的对象(如整数、字符串等)。以下是具体的行为描述: - **针对实例对象**: 如果我们有一个类 `A` 和它的实例 `a_instance`,那么可以通过 `a_instance.__class__` 获取到类 `A`。 - **针对类本身**: 类也可以看作是一种特殊的对象,在这种情况下,`A.__class__` 将返回 `<type 'type'>` 或者更具体的元类(如果指定了的话)[^2]。 #### 示例代码展示 下面是一些简单的例子来演示如何使用以及理解这个概念: ```python class Example: pass example_instance = Example() print(example_instance.__class__) # 输出:<class '__main__.Example'> print(Example.__class__) # 输出:<class 'type'> # 对于基本数据类型同样适用 num = 5 str_obj = "hello" list_obj = [] print(num.__class__) # 输出:<class 'int'> print(str_obj.__class__) # 输出:<class 'str'> print(list_obj.__class__) # 输出:<class 'list'> ``` #### 进一步探讨——结合其他特性 当涉及到继承或者多重继承时,`__class__` 可以帮助分析复杂的层次结构关系;另外配合反射技术可以实现动态行为控制等功能[^3]。 例如利用工厂模式可以根据传入参数决定生成哪个子类的实例,并借助 `__class__.__name__` 打印当前实际产生的类别名称以便调试记录日志信息等等操作都非常方便实用。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值