您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – 子类化C模块中定义的类型时忽略的方法

5b51 2022/1/14 8:21:59 python 字数 3621 阅读 520 来源 www.jb51.cc/python

我正在将C模块中定义的类型子类化为别名的一些属性和方法,以便我的脚本在不同的上下文中工作.如何让它工作,我必须手动调整我班级的字典?如果我没有在dictionnary中添加对DistanceTo的引用,我得到Point3d没有名为DistanceTo的属性.class Point3d(App.Base.Vector): def __new__(c

概述

我正在将C模块中定义的类型子类化为别名的一些属性方法,以便我的脚本在不同的上下文中工作.

如何让它工作,我必须手动调整我班级的字典?如果我没有在dictionnary中添加对DistanceTo的引用,我得到Point3d没有名为DistanceTo的属性.

class Point3d(App.Base.Vector):
      def __new__(cls,x,y,z):
          obj = super(Point3d,cls).__new__(cls)
          obj.x,obj.y,obj.z = x,z
          obj.__dict__.update({
               'X':property(lambda self: self.x),'Y':property(lambda self: self.y),'Z':property(lambda self: self.z),'DistanceTo':lambda self,p: self.distanceToPoint(p)})
          return obj
      def DistanceTo(self,p): return self.distanceToPoint(p)

我在想,一旦__new__返回了一个实例,我仍然可以使用方法属性来填充它.任何人都可以对此有所了解吗?

编辑:我导入的模块是FreeCAD. C基类型定义为there.然后,从此定义here导出Vector

编辑2:我也尝试了以下内容

class Point3d(App.Base.Vector):
      def __new__(cls,z
          obj.__dict__.update({
               'X': x,'Y': y,'Z': z,p: self.distanceToPoint(p)})
           return obj
       def DistanceTo(self,p): return self.distanceToPoint(p)

并且在创建第二个点之后,无论在创建实例时传递了什么x,z参数,Point3d p都返回p.X,p.Y和p.Z的最后一个点的值. p.x,p.y,p.z返回预期值.它似乎表明字典是在实例之间共享的.

编辑3:问题解决了! Py_TPFLAGS_BASETYPE位设置为零以防止子类化,如下面的答案中所述.

class Point3d(App.Base.Vector):
    def __init__(self,z):
        super().__init__(x,z)  # or maybe  super().__init__([x,z])

    @property
    def X(self):
        return self[0]  # guessing that App.Base.Vector works like a list

    @property.setter
    def X(self,value):
        self[0] = value

    # Y and Z likewise.

总结

以上是编程之家为你收集整理的python – 子类化C模块中定义的类型时忽略的方法全部内容,希望文章能够帮你解决python – 子类化C模块中定义的类型时忽略的方法所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶