python自定义类_python 自定义类写法(继承,重写)

Django应用

#重写函数,返回json

class JSONResponse(HttpResponse):

"""

An HttpResponse that renders its content into JSON.

"""

def __init__(self, data, **kwargs):

content = JSONRenderer().render(data)

#返回json

kwargs['content_type'] = 'application/json'

super(JSONResponse, self).__init__(content, **kwargs)

模板

# 模板1

class LayerChart(TopLevelMixin, _EncodingMixin, core.TopLevelLayerSpec):

def __init__(self, data=Undefined, layer=(), **kwargs):

for spec in layer:

_check_if_valid_subspec(spec, "LayerChart")

_check_if_can_be_layered(spec)

super(LayerChart, self).__init__(data=data, layer=list(layer), **kwargs)

self.data, self.layer = _combine_subchart_data(self.data, self.layer)

# 模板2

#1. 定义

from log import logger

class AsstException(Exception):

def __init__(self, message):

super().__init__(message)

logger.error(message)

#2. 使用

from exception import AsstException

class Messenger(object):

def __init__(self, sc_key):

if not sc_key:

raise AsstException('sc_key can not be empty')

#模板3

# 装饰类中函数的装饰器第一个参数是self

def connection_closed_handler(function):

@wraps(function)

def _wrap(inst, *args, **kwargs):

try:

return function(inst, *args, **kwargs)

except (ConnectionClosedException, WebSocketConnectionClosedException):

inst.logger.warn("the connection lost. Resetting ...")

inst.reset(args[1])

return function(inst, *args, **kwargs)

return _wrap

#模板4

class A:

def add(self, x):

y = x+1

print(y)

class B(A):

def add(self, x):

super().add(x)

b = B()

b.add(2) # 3

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值