python2 description不起作用

本文介绍如何使用Python描述符确保类属性仅接受特定类型的数据,通过实例演示了当尝试为属性分配错误类型值时如何引发异常。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

python2.7

代码为:

class Integer:
    def __init__(self,name):
        self.name=name
    def __get__(self,instance,cls):
        if instance is None:
            return self
        else:
            return instance.__dict__[self.name]

    def __set__(self,instance,value):
        if not isinstance(value,int):
            raise TypeError('Expected an int')
        instance.__dict__[self.name]=value

    def __delete__(self,instance):
        del instance.__dict__[self.name]


class Point:
    x=Integer('x')
    y=Integer('y')
    def __init__(self,x,y):
        self.x=x
        self.y=y

if __name__=="__main__":
    p=Point(2,3)
    print p.x
    p.y=2.3
    print p.y
输出结果为:

2
2.3

可以看到p.y居然可以为小数。也就是说description不起作用。。


原因:

把类的声明从class Integer改为class Integer(object),其他的类定义都是类似:


最终代码为:

__author__ = 'Administrator'

class Integer(object):
    def __init__(self,name):
        self.name=name
    def __get__(self,instance,cls):
        if instance is None:
            return self
        else:
            return instance.__dict__[self.name]

    def __set__(self,instance,value):
        if not isinstance(value,int):
            raise TypeError('Expected an int')
        instance.__dict__[self.name]=value

    def __delete__(self,instance):
        del instance.__dict__[self.name]


class Point(object):
    x=Integer('x')
    y=Integer('y')
    def __init__(self,x,y):
        self.x=x
        self.y=y

if __name__=="__main__":
    p=Point(2,3)
    print p.x
    p.y=2.3
    print p.y
最终结果为:
2
Traceback (most recent call last):
  File "G:/pycode/SimpleCode/PY_CookBook/chapter8/one.py", line 31, in <module>
    p.y=2.3
  File "G:/pycode/SimpleCode/PY_CookBook/chapter8/one.py", line 14, in __set__
    raise TypeError('Expected an int')
TypeError: Expected an int



### Python `print` 函数的用法说明 在 Python 中,`print()` 是一个内置函数,用于将指定对象打印到标准输出设备(如屏幕)。此功能支持多个参数,并允许通过关键字参数自定义输出格式。 #### 基本语法 ```python print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False) ``` - **objects**: 要打印的对象。可以是一个或多个表达式,之间用逗号分隔。 - **sep**: 字符串类型的分隔符,默认为空格 `' '`,用来间隔传递给函数的对象。 - **end**: 打印结束后的附加字符,默认为换行符 `\n`。 - **file**: 输出流,默认指向控制台 (stdout),也可以重定向至文件或其他类文件对象。 - **flush**: 如果设置为 True,则会强制刷新输出缓冲区[^1]。 #### 使用示例 下面是一些常见的使用场景: ##### 单个字符串输出 最简单的形式就是只传入单个字符串作为参数: ```python print("Hello world!") ``` ##### 多个值输出并指定分隔符 当有多个值需要输出时,可以通过 `sep` 参数改变默认的空格分隔方式: ```python print('a', 'b', 'c', sep=',') ``` ##### 自定义结尾字符 通常每条语句之后都会自动加上新行,但有时可能希望连续显示而不换行,这时就可以调整 `end` 参数: ```python for i in range(5): print(i, end=" ") ``` ##### 向文件写入数据 除了向终端发送消息外,还可以利用 `file` 参数把内容保存到外部文件里: ```python with open('output.txt', 'w') as f: print('writing to a file...', file=f) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值