• Python动态生成方法


    背景:想要通过读取配置文件动态生成方法

    实践1

    使用关键字exec实现生成方法,参考 https://www.cnblogs.com/wjlv/p/14276827.html

    m = """
    def fn(a,b):
        c=2
        s=a+b+c
        return s
    """
    
    exec(m)
    
    print(fn(3, 6))
    

    执行结果:

    11
    

    实践2

    直接给类和方法绑定自定义方法 A.fun=fun

    class A():
        dd = 37
    
        def __init__(self, de):
            self.de = de
    
    
    print(globals())
    m = """
    def fn(a,b):
        c=2
        s=a+b+c
        return s
    """
    
    exec(m)
    print(globals())
    
    if __name__ == '__main__':
        c = 17
        a = A(35)
        print('
    
    
    ')
        print(A.__dict__)
        print(a.__dict__)
    

    执行结果:

    可以看到方法的确已经生成了,但是此时无论是类A还是实例a都没有这个方法。下面给这个类加上此方法:

    
    class A():
        dd = 37
    
        def __init__(self, de):
            self.de = de
    
    
    m = """
    def fn(a,b):
        c=2
        s=a+b+c
        return s
    """
    
    exec(m)
    
    A.fn = fn  # 这里需要注意的是,fn函数会被当做 staticmethod,所以是不能被实例调用的
    
    if __name__ == '__main__':
        c = 17
        a = A(35)
        print(A.__dict__)
        print(A.fn(5, 6))
        print(a.__dict__)
        # print(a.fn(5, 6))  # 报错  TypeError: fn() takes 2 positional arguments but 3 were given   因为实例调用多传了self
    

    执行结果:

    优化实践2

    使用types给类添加方法,参考 https://blog.csdn.net/qdpython/article/details/107879804

    import types
    
    
    class A():
        dd = 37
    
        def __init__(self, de):
            self.de = de
    
        def ss(self, a):
            self.de = self.de + a
    
    
    m = """
    def fn(a,b):
        c=2
        s=b+c
        return s
    """
    
    exec(m)
    
    A.f = types.MethodType(fn, A)  # 这里fn函数会被当做类方法,第一个参数a,会被当作self传入,所以类和实例都能调用此方法
    
    if __name__ == '__main__':
        c = 17
        a = A(35)
        print(A.__dict__)
        print(A.f(6))
        print(a.__dict__)
        print(a.f(3))
    

    执行结果:

    可以看到无论是实例还是类,均能够使用自定义的方法

    这里补充下,如果只想给实例添加私有自定义方法,可以 a.fun=types.MethodType(fn, a)

    import types
    
    
    class A():
        dd = 37
    
        def __init__(self, de):
            self.de = de
    
        def ss(self, a):
            self.de = self.de + a
    
    
    m = """
    def fn(a,b):
        c=2
        s=b+c
        return s
    """
    
    exec(m)
    
    if __name__ == '__main__':
        c = 17
        a = A(35)
        a.f = types.MethodType(fn, a)
        print(A.__dict__)
        # print(A.f(6))  # AttributeError: type object 'A' has no attribute 'f' 实例的私有方法,类无法调用
        print(a.__dict__)
        print(a.f(3))
    

    执行结果: 实例的私有方法,类无法调用

  • 相关阅读:
    弱网测试及app弱网测试点
    adb相关记录
    vmware虚拟机启动centos黑屏
    python中+与+=,=+
    mysql客户端不能插入中文字符
    wampserver3 集成环境 启动Apache失败
    python 局部变量与全局变量
    pyhton 函数参数,递归函数,高阶函数(一点点笔记)
    在CentOS7安装redis服务器
    Servlet生命周期的四个阶段
  • 原文地址:https://www.cnblogs.com/wjlv/p/14419348.html
Copyright © 2020-2023  润新知