Um sistema OOP robusto no estilo Java para Python, com suporte para estática, encapsulamento e herança.
Vista sobre Pypi / construído por Kento Nishi e Ronak Badhe
O Python ++ permite que os programadores do Python usem princípios de programação orientados a objetos no Python.
O pacote está disponível no Pypi. Você pode instalar o pacote com o seguinte comando:
pip install pythonppVocê pode importar o Python ++ usando uma instrução de importação curinga.
from pythonpp import * Declare as classes Python ++ com o decorador @PythonPP .
@ PythonPP
class MyClass :
pass # class code here Declare variáveis e métodos para classes Python ++ dentro namespace .
@ PythonPP
class MyClass :
def namespace ( public , private ):
pass # methods and variables here O código no namespace tem acesso aos seguintes escopos:
| Escopo | Descrição |
|---|---|
public | O escopo da instância pública. |
private | O escopo da instância privada. |
public.static | O escopo estático público. |
private.static | O escopo estático privado. |
Declare os inicializadores estáticos das classes Python ++ usando o decorador @staticinit . Os inicializadores estáticos não têm acesso a variáveis e métodos de instância. Inicializadores estáticos não podem ter parâmetros de entrada.
@ PythonPP
class MyClass :
def namespace ( public , private ):
@ staticinit
def StaticInit ():
public . static . publicStaticVar = "Static variable (public)"
private . static . privateStaticVar = "Static variable (private)" Como alternativa, as variáveis estáticas podem ser declaradas no namespace nua se as atribuições da variável forem constantes . Usando declarações variáveis estáticas nuas não são recomendadas .
Os construtores podem ser declarados usando o decorador @constructor . Os construtores podem ter parâmetros de entrada.
@ PythonPP
class MyClass :
def namespace ( public , private ):
@ constructor
def Constructor ( someValue ):
public . publicInstanceVar = "Instance variable (public)"
public . userDefinedValue = someValue Os métodos são declarados usando o decorador @method(scope) com escopos public e private no namespace .
@ PythonPP
class MyClass :
def namespace ( public , private ):
@ method ( public )
def publicMethod ():
pass # public instance method here
@ method ( private )
def privateMethod ():
pass # private instance method here
@ method ( public . static )
def publicStaticMethod ():
pass # public static method here
@ method ( private . static )
def privateStaticMethod ():
pass # private static method here Declare métodos embutidos especiais usando o decorador @special .
@ PythonPP
class MyClass :
def namespace ( public , private ):
@ special
def __str__ ():
return "Some string value"As classes podem estender outras classes usando a herança da classe Python padrão.
@ PythonPP
class ParentClass :
def namespace ( public , private ):
@ staticinit
def StaticInit ():
public . static . staticVar = "Static variable"
@ constructor
def Constructor ( param ):
print ( "Parent constructor" )
public . param = param
@ PythonPP
class ChildClass ( ParentClass ): # ChildClass extends ParentClass
def namespace ( public , private ):
@ staticinit
def StaticInit ():
ParentClass . staticinit () # Call parent static initializer
public . static . staticVar2 = "Static variable 2"
@ constructor
def Constructor ( param ):
# Call parent constructor
ParentClass . constructor ( param ) from pythonpp import *
@ PythonPP
class ParentClass :
def namespace ( public , private ):
@ staticinit
def StaticInit ():
public . static . publicStaticVar = "Public static variable"
private . static . privateStaticVar = "Private static variable"
@ constructor
def Constructor ( parameter ):
private . privateVariable = parameter
@ PythonPP
class ChildClass ( ParentClass ):
def namespace ( public , private ):
@ staticinit
def StaticInit ():
ParentClass . staticinit ()
@ constructor
def Constructor ( parameter ):
ParentClass . constructor ( parameter )
public . publicVariable = "Public variable"
private . privateVariable = "Private variable"
@ method ( public )
def getPrivateVariable ():
return private . privateVariable
@ method ( public . static )
def getPrivateStaticVar ():
return private . static . privateStaticVar
@ special
def __str__ ():
return "ChildClass object" print ( ChildClass . publicStaticVar )
# > Private static variable
print ( ChildClass . getPrivateStaticVar ())
# > Private static variable
obj = ChildClass ( "Parameter value" )
print ( obj )
# > ChildClass object
print ( obj . publicVariable )
# > Public variable
print ( obj . getPrivateVariable ())
# > Parameter value
try :
obj . privateVariable # results in an error
except Exception as e :
print ( e )
# > 'ChildClass' object has no attribute 'privateVariable' Você pode ver o exemplo completo do Jupyter Notebook aqui.