智慧 + 毅力 = 无所不能

正确性、健壮性、可靠性、效率、易用性、可读性、可复用性、兼容性、可移植性...
随笔 - 991, 文章 - 0, 评论 - 27, 阅读 - 341万

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

Python中动态创建类实例

Posted on   Bill Yuan  阅读(6848)  评论(0编辑  收藏  举报

例如: 

import mymodule
myobject
= mymodule.myclass()
或者 
from mymodule import myclass
myobject
= myclass()
如果要在程序中动态地创建类实例,也一样要分两步走,例如: 
m = __import__('mymodule')
c
= getattr(m, 'myclass')
myobject
= c()

但是要注意:如果myclass并不在mymodule的自动导出列表中(__all__),则必须显式地导入,例如: 
m = __import__('mymodule', globals(), locals(), ['myclass'])
c
= getattr(m, 'myclass')
myobject
= c()

若要封装的规范一些,可以这样来做:


复制代码
代码
class Activator:
'''本类用来动态创建类的实例'''
@staticmethod
def createInstance(class_name, *args, **kwargs):
'''动态创建类的实例。
[Parameter]
class_name - 类的全名(包括模块名)
*args - 类构造器所需要的参数(list)
*kwargs - 类构造器所需要的参数(dict)
[Return]
动态创建的类的实例
[Example]
class_name = 'knightmade.logging.Logger'
logger = Activator.createInstance(class_name, 'logname')
'''
(module_name, class_name)
= class_name.rsplit('.', 1)
module_meta
= __import__(module_name, globals(), locals(), [class_name])
class_meta
= getattr(module_meta, class_name)
object
= class_meta(*args, **kwargs)
return object
复制代码

转自:http://www.python8.org/a/fenleiwenzhang/yuyanjichu/2010/1001/566.html

(评论功能已被禁用)
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
点击右上角即可分享
微信分享提示