五大案例学会类属性 | 手把手教你入门Python之六十九

简介: 通过案例练习,熟悉之前所学的内容。

上一篇:文件的打开与关闭 | 手把手教你入门Python之六十八
下一篇:文件的读写 | 手把手教你入门Python之七十

本文来自于千锋教育在阿里云开发者社区学习中心上线课程《Python入门2020最新大课》,主讲人姜伟。

案例讲解

1、设计两个类:
一个点类,属性包括x,y坐标。
一个Rectangle类(矩形),属性有左上角和右下角的坐标
方法:1.计算矩形的面积;2.判断点是否在矩形内
实例化一个点对象,一个正方形对象,输出矩形的面积、输出点是在矩形内

class Point(object):
    # Point 方法在创建时,需要两个int类型的参数,用来表示x,y坐标
    def __init__(self, x: int, y: int):
        self.x = x 
        self.y = y


class Rectangle(object):
    def __init__(self, top_left: Point, bottom_right: Point):
        self.top_left = top_left
        self.bottom_right = bottom_right

    def get_area(self):
        # 面积:长 * 宽
        length = abs(self.bottom_right.x - self.top_left.x)
        width = abs(self.top_left.y - self.bottom_right.y)
        return length * width

    def is_inside(self, point):
#        if self.bottom_right.x >= point.x >= self.top_left.x and self.top_left.y >= point.y >= self.bottom_right.y:
#            return True
#        else:
#           return False
        return self.bottom_right.x >= point.x >= self.top_left.x and self.top_left.y >= point.y >= self.bottom_right.y

p1 = Point(4, 20)   # 定义左上角的点
p2 = Point(30, 8)  # 定义右下角的点

r = Rectangle(p1, p2)  # 把左上角和右下角的点传递给矩形
print(r.get_area())   # 312

# p = Point(10;, 13)  # True
p = Point(20;, 30)  # False
print(r.is_inside(p))  

2、写一个计算器类,可以进行加、减、乘、除计算

class Calculator(object):
    @staticmethod
    def add(a, b):
        return a + b
    
    @staticmethod
    def sub(a, b):
        return a - b

    @staticmethod
    def mul(a, b):
        return a * b
    
    @staticmethod
    def div(a, b):
        return a / b

print(Calculator.add(4, 5))  # 9
print(Calculator.sub(4, 5))  # -1
print(Calculator.mul(4, 5))  # 20
print(Calculator.div(4, 5))  # 0.8

3、创建一个Person类,添加一个类字段用来统计Person类的对象的个数

class Person(object):
    __count = 0  # 类属性

    def __new__(cls, *args, **kwargs):
        x = object.__new__(cls)  # 申请内存,创建一个对象,并设置类型是 Person 类
        return x

    def __init__(self, name, age):
        Person.__count += 1
        self.name = name
        self.age = age
    
    @classmethod
    def get_count(cls):
        return cls.__count


# 每次创建对象,都会调用 __new__ 和 __init__ 方法
# 调用 __new__ 方法,用来申请内存
# 如果不重写 __new__ 方法,它会自动找object 的 __new__
# object 的 __new__ 方法,默认实现是申请了一段内存,创建一个对象
p1 = Person('张三', 18)
p2 = Person('李四', 19)
p3 = Person('jack', 20)

# print(Person.count)  # 3

print(p1, p2, p3)
print(Person.get_count())  # 3

# p4 = object.__new__(Person)  # 申请了内存,创建了一个对象,并设置它的类型是Person
# p4.__init__('tony', 23)
# print(p4)

4、建立一个汽车类Auto,包括轮胎个数,汽车颜色,车身重量,速度等属性,并通过不同的构造方法创建实例。至少要求汽车能够加速、减速、停车。再定义一个小汽车类CarAuto继承Auto并添加空调、导航属性,并且重新实现方法覆盖加速、减速的方法

class Auto(object):
    def __init__(self, color, weight, speed=0, wheel_count=4):
        self.wheel_count = wheel_count
        self.color = color
        self.weight = weight
        self.speed = speed

    def change_speed(self, x):
        """
        修改车速
        :param x: 表示要修改的车速值。如果是正数,表示加速,负数表示减速,0表示停车
        """
        if x == 0:
            self.speed = 0  # 如果传递的参数0,表示要停车
            return
        self.speed += x
        if self.speed <= 0 and x < 0
            return  # return 后面可以什么数据都不加,表示函数结束
        
class CarAuto(Auto):
    def __init__(self, color, weight, ac, navigator, speed=0, wheel_count=4):
        super(CarAuto, self).__init__(color, weight, speed, wheel_count)
        self.navigator = navigator
        self.ac = ac

car = CarAuto('白色', 1.6, '美的', 'Android', 10, 5)

car.change_speed(30)
print(car.speed)   # 30

car.change_speed(-40)
print(car.speed)   # 0

5.有一个银行账户类Account,包括名字,余额等属性,方法有存钱、取钱、查询余额的操作。要求:
1.在存钱时,注意存款数据的格式
2.取钱时,要判断余额是否充足,余额不够的时候要提示余额不足

class Account(object):
    def __init__(self, name, balance):
        self.name = name
        self.balance = balance
    
    def save_money(self, money):
        assert isinstance(money, float) or isinstance(money, int), '请注意存钱数据的格式'
        self.balance += money

    def take_money(self, money):
        if self.balance < money:
            print('余额不足')
        else:
            self.balance -= money

    def check_balance(self):
        return self.balance

a = Account('张三', 8000)
a.save_money(10000)
a.take_money(1000)
print('当前余额:', a.check_balance())
a.take_money(20000)
print('当前余额:', a.check_balance())

image.png

配套视频

相关文章
|
1月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
271 7
|
2月前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
314 1
|
1月前
|
Java 数据处理 索引
(Pandas)Python做数据处理必选框架之一!(二):附带案例分析;刨析DataFrame结构和其属性;学会访问具体元素;判断元素是否存在;元素求和、求标准值、方差、去重、删除、排序...
DataFrame结构 每一列都属于Series类型,不同列之间数据类型可以不一样,但同一列的值类型必须一致。 DataFrame拥有一个总的 idx记录列,该列记录了每一行的索引 在DataFrame中,若列之间的元素个数不匹配,且使用Series填充时,在DataFrame里空值会显示为NaN;当列之间元素个数不匹配,并且不使用Series填充,会报错。在指定了index 属性显示情况下,会按照index的位置进行排序,默认是 [0,1,2,3,...] 从0索引开始正序排序行。
219 0
|
1月前
|
数据采集 监控 数据库
Python异步编程实战:爬虫案例
🌟 蒋星熠Jaxonic,代码为舟的星际旅人。从回调地狱到async/await协程天堂,亲历Python异步编程演进。分享高性能爬虫、数据库异步操作、限流监控等实战经验,助你驾驭并发,在二进制星河中谱写极客诗篇。
Python异步编程实战:爬虫案例
|
1月前
|
Cloud Native 算法 API
Python API接口实战指南:从入门到精通
🌟蒋星熠Jaxonic,技术宇宙的星际旅人。深耕API开发,以Python为舟,探索RESTful、GraphQL等接口奥秘。擅长requests、aiohttp实战,专注性能优化与架构设计,用代码连接万物,谱写极客诗篇。
Python API接口实战指南:从入门到精通
|
1月前
|
存储 Java 调度
Python定时任务实战:APScheduler从入门到精通
APScheduler是Python强大的定时任务框架,通过触发器、执行器、任务存储和调度器四大组件,灵活实现各类周期性任务。支持内存、数据库、Redis等持久化存储,适用于Web集成、数据抓取、邮件发送等场景,解决传统sleep循环的诸多缺陷,助力构建稳定可靠的自动化系统。(238字)
457 1
|
2月前
|
调度 数据库 Python
Python异步编程入门:asyncio让并发变得更简单
Python异步编程入门:asyncio让并发变得更简单
180 5
|
2月前
|
缓存 供应链 芯片
电子元件类商品 item_get - 商品详情接口深度分析及 Python 实现
电子元件商品接口需精准返回型号参数、规格属性、认证及库存等专业数据,支持供应链管理与采购决策。本文详解其接口特性、数据结构与Python实现方案。
|
2月前
|
数据采集 存储 XML
Python爬虫入门(1)
在互联网时代,数据成为宝贵资源,Python凭借简洁语法和丰富库支持,成为编写网络爬虫的首选。本文介绍Python爬虫基础,涵盖请求发送、内容解析、数据存储等核心环节,并提供环境配置及实战示例,助你快速入门并掌握数据抓取技巧。
|
2月前
|
大数据 数据处理 数据安全/隐私保护
Python3 迭代器与生成器详解:从入门到实践
简介:本文深入解析Python中处理数据序列的利器——迭代器与生成器。通过通俗语言与实战案例,讲解其核心原理、自定义实现及大数据处理中的高效应用。
152 0

推荐镜像

更多
下一篇
oss云网关配置