Сильная система ООП в стиле Java для Python, при поддержке статики, инкапсуляции и наследия.
Посмотреть на PYPI / Построен Кенто Ниши и Ронак Бадхе
Python ++ позволяет программистам Python использовать объектно -ориентированные принципы программирования в Python.
Пакет доступен на PYPI. Вы можете установить пакет со следующей командой:
pip install pythonppВы можете импортировать Python ++ с помощью оператора импорта подстановочного знака.
from pythonpp import * Объявите классы Python ++ с декоратором @PythonPP .
@ PythonPP
class MyClass :
pass # class code here Объявите переменные и методы для классов Python ++ в namespace .
@ PythonPP
class MyClass :
def namespace ( public , private ):
pass # methods and variables here Код в namespace имеет доступ к следующим областям:
| Объем | Описание |
|---|---|
public | Общественный экземпляр. |
private | Частный экземпляр. |
public.static | Общественная статическая область. |
private.static | Частная статическая область. |
Объявите статические инициализаторы для классов Python ++, используя декоратор @staticinit . Статические инициализаторы не имеют доступа к переменным экземпляра и методов. Статические инициализаторы не могут иметь входные параметры.
@ PythonPP
class MyClass :
def namespace ( public , private ):
@ staticinit
def StaticInit ():
public . static . publicStaticVar = "Static variable (public)"
private . static . privateStaticVar = "Static variable (private)" В качестве альтернативы, статические переменные могут быть объявлены в namespace голой, если назначения переменной постоянны . Использование голых статических переменных объявлений не рекомендуется .
Конструкторы могут быть объявлены с использованием декоратора @constructor . Конструкторы могут иметь входные параметры.
@ PythonPP
class MyClass :
def namespace ( public , private ):
@ constructor
def Constructor ( someValue ):
public . publicInstanceVar = "Instance variable (public)"
public . userDefinedValue = someValue Методы объявляются с использованием декоратора @method(scope) с public и private областями в 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 Объявите специальные встроенные методы с использованием декоратора @special .
@ PythonPP
class MyClass :
def namespace ( public , private ):
@ special
def __str__ ():
return "Some string value"Классы могут расширять другие классы, используя стандартное наследство класса Python.
@ 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' Вы можете просмотреть полный пример записной книжки Jupyter здесь.