Python实验四

面向对象程序设计

实验目的:

(1)理解类与对象的概念,掌握类的定义和使用方法。
(2)熟悉类的成员和方法的类型,掌握其定义和使用方法。
(3)掌握类的属性及其使用方法。
(4)掌握派生类的创建和使用方法。
(5)理解类的多态含义,掌握类的多态实现方法。
(6)掌握抽象类和抽象方法的使用方法。

实验内容:

1、编程实现如下功能:
(1)定义一个抽象类Shape,在抽象类Shape中定义求面积getArea()和周长getPerimeter()的抽象方法。
(2)分别定义继承抽象类Shape的3个子类即Triangle、Rectangle和Circle,在这3个子类中重写Shape中的方法getArea()和getPerimeter()。
(3)创建类Triangle、Rectangle、Circle的对象,对3个类中的方法进行调用测试。

"""
@Author:*Melon
@Date:2022.11.25
@CSDN:*Melon

"""

# (1)定义一个抽象类Shape,在抽象类Shape中定义求面积getArea()和周长getPerimeter()的抽象方法。
# (2)分别定义继承抽象类Shape的3个子类即Triangle、Rectangle和Circle,在这3个子类中重写Shape中的方法getArea()和getPerimeter()。
# (3)创建类Triangle、Rectangle、Circle的对象,对3个类中的方法进行调用测试。
import abc
import math


# 抽象类,用abc库,只需要声明函数,不需要写具体功能,不能够实例化.类似C+纯虚函数
class Shape(metaclass=abc.ABCMeta):
    # 面积
    def getArea(self):
        pass

    # 周长
    def getPerimeter(self):
        pass


# 三角形
class Triangle(Shape):
    def __init__(self, a, b, c):
        self.a = a
        self.b = b
        self.c = c

    def getArea(self):
        return 0.25 * math.sqrt((self.a + self.b + self.c) * (self.a + self.b - self.c) * (self.b + self.c - self.a) * (
                self.a + self.c - self.b))

    def getPerimeter(self):
        return self.a + self.b + self.c

    # 判断三边关系
    def judgeInput(self):
        a1 = self.a + self.b - self.c
        a2 = (self.a - self.b) - self.c
        b1 = self.b + self.c - self.a
        b2 = (self.b - self.c) - self.a
        c1 = self.a + self.c - self.b
        c2 = (self.a - self.c) - self.b
        if (a1 > 0 and a2 < 0) and (b1 > 0 and b2 < 0) and (c1 > 0 and c2 < 0):
            return True
        else:
            return False


# 矩形
class Rectangle(Shape):
    def __init__(self, a, b):
        self.a = a
        self.b = b

    def getArea(self):
        return self.a * self.b

    def getPerimeter(self):
        return (self.a + self.b) * 2


# 圆
class Circle(Shape):
    def __init__(self, r):
        self.r = r

    def getArea(self):
        return 3.14 * self.r ** 2

    def getPerimeter(self):
        return 2 * math.pi * self.r


if __name__ == '__main__':
    a1, a2, a3 = map(int, input("请输入三角形三边:").split(" "))
    t1 = Triangle(a1, a2, a3)
    if t1.judgeInput():
        print(f"三角形面积={t1.getArea()}")
        print(f"三角形周长={t1.getPerimeter()}")
    else:
        print("输入的三边长不能构成三角形")
    b1, b2 = map(int, input("请输入矩形两边:").split(" "))
    r1 = Rectangle(b1, b2)
    print(f"矩形面积={r1.getArea()}")
    print(f"矩形周长={r1.getPerimeter()}")
    r1 = int(input("请输入圆的半径r1:"))
    c1 = Circle(r1)
    print("圆面积%.2f" % c1.getArea())
    print("圆周长%.2f" % c1.getPerimeter())

2、设计一个“超市进销存管理系统”,要求如下:
(1)系统包括7中操作,分别是:1.查询所有商品;2.添加商品;3.修改商品;4.删除商品;5.卖出商品;6.汇总;-1.退出系统。
(2)选择操作序号“1”,显示所有商品。
(3)选择操作序号“2”,添加新的商品(包括商品名称、数量和进货价格)。
(4)选择操作序号“3”,修改商品。
(5)选择操作序号“4”,删除商品。
(6)选择操作序号“5”,卖出商品(包括商品名称、数量和售出价格)。
(7)选个操作序号“6”,汇总当天卖出商品,包括每种销售商品名称、数量、进货总价、销售总价等。
(8)选择操作序号“-1”,退出系统。

"""
@Author:*Melon
@Date:2022.11.25
@CSDN:*Melon

"""


# 2、设计一个“超市进销存管理系统”,要求如下:
# (1)系统包括7中操作,分别是:1.查询所有商品;2.添加商品;3.修改商品;4.删除商品;5.卖出商品;6.汇总;-1.退出系统。
# (2)选择操作序号“1”,显示所有商品。
# (3)选择操作序号“2”,添加新的商品(包括商品名称、数量和进货价格)。
# (4)选择操作序号“3”,修改商品。
# (5)选择操作序号“4”,删除商品。
# (6)选择操作序号“5”,卖出商品(包括商品名称、数量和售出价格)。
# (7)选个操作序号“6”,汇总当天卖出商品,包括每种销售商品名称、数量、进货总价、销售总价等。
# (8)选择操作序号“-1”,退出系统。


# 定义库存类
class Goods:
    # 有参构造初始化
    def __init__(self, name, num, cin, cout):
        self.name = name
        self.num = num
        self.cin = cin
        self.cout = cout

    def __str__(self):
        state = "已售完"
        if self.num == 0:
            return '名称:%s , 数量:%d %s, 进货价格:%.2f ,售出价格:%.2f ' % (self.name, self.num, state, self.cin, self.cout)
        else:
            return '名称:%s , 数量:%d , 进货价格:%.2f ,售出价格:%.2f ' % (self.name, self.num, self.cin, self.cout)


# 已售出类
class gGoods:
    def __init__(self, name, gnum, gcin, gcout):
        self.name = name
        self.gnum = gnum
        self.gcin = gcin
        self.gcout = gcout

    def __str__(self):
        return '名称:%s , 卖出数量:%d , 进货价格:%.2f ,卖出价格:%.2f ' % (self.name, self.gnum, self.gcin, self.gcout)


# 定义管理商品类
class GoodsManager:
    go = []  # 库存
    js = []  # 售出

    # 构造方法,初始化加三个商品
    def init(self):
        self.go.append(Goods('牛奶', 5, 40, 60))
        self.go.append(Goods('面包', 5, 10, 20))
        self.js.append(gGoods('饼干', 10, 30, 60))

    # 菜单
    def Menu(self):
        self.init()
        print('\"超市进销存管理系统\"菜单:')
        print("1.显示所有商品")
        print("2.添加新的商品")
        print("3.修改商品信息")
        print("4.删除商品")
        print("5.卖出商品")
        print("6.汇总")
        print("-1.退出")
        print("***********************************")
        while True:
            SN = int(input("请输入操作序号:"))
            if SN in [-1, 1, 2, 3, 4, 5, 6]:
                if SN == -1:
                    print("已经退出")
                    break
                if SN == 1:
                    self.Show_all()
                elif SN == 2:
                    self.Add()
                elif SN == 3:
                    self.Modify()
                elif SN == 4:
                    self.Delete()
                elif SN == 5:
                    self.Shop()
                elif SN == 6:
                    self.Summary()
            else:
                print("输入有误!")

    # 显示
    def Show_all(self):
        for goods in self.go:
            print(str(goods))

    # 添加
    def Add(self):
        goods_name = input("请输入商品名称:")
        ret = self.check(goods_name)
        if ret is not None:
            print('商品已经存在')
            print('是否增加商品数量:(y/n)')
            while True:
                pd = input()
                if pd == 'y':
                    goods_num = int(input("请输入商品的数量:"))
                    old_goods = Goods(goods_name, goods_num + ret.num, ret.cin, ret.cout)
                    self.go.remove(ret)
                    self.go.append(old_goods)
                    print("增加成功")
                    break
                elif pd == 'n':
                    print("已经返回")
                    break
                else:
                    print("输入有误,重新输入:")

        else:
            goods_num = int(input("请输入商品的数量:"))
            goods_cin = float(input("请输入商品进货价格:"))
            goods_cout = float(input("请输入商品出货价格:"))
            if goods_num > 0 and goods_cin > 0 and goods_cout > 0:
                new_goods = Goods(goods_name, goods_num, goods_cin, goods_cout)
                self.go.append(new_goods)
                print("添加成功")
            else:
                print("输入错误!")

    # 修改
    def Modify(self):
        goods_name = input("请输入需要修改的商品名称:")
        ret = self.check(goods_name)
        if ret is not None:
            print(ret)
            goods_name1 = input("请输入修改后商品的名称:")
            goods_num = int(input("请输入修改后商品的数量:"))
            goods_cin = float(input("请输入修改后商品进货价格:"))
            goods_cout = float(input("请输入修改后商品出货价格:"))
            old_goods = Goods(goods_name1, goods_num, goods_cin, goods_cout)
            self.go.remove(ret)
            self.go.append(old_goods)
            print("修改成功")
        else:
            print("没有此商品!")

    # 检查,修改删除卖出之前先调用检查是否存在商品
    def check(self, goods_name):
        for goods in self.go:
            if goods.name == goods_name:
                return goods
        else:
            return None

    def checkjs(self, goods_name):
        for goods in self.js:
            if goods.name == goods_name:
                return goods
        else:
            return None

    # 删除
    def Delete(self):
        goods_name = input("请输入需要删除的商品名称:")
        ret = self.check(goods_name)
        if ret is not None:
            print(ret)
            print('是否删除商品:(y/n)')
            while True:

                pd = input()
                if pd == 'y':
                    self.go.remove(ret)
                    print("删除成功")
                    break
                elif pd == 'n':
                    print("已经返回")
                    break
                else:
                    print("输入有误,重新输入:")
        else:
            print("没有此商品!")

    # 卖出
    def Shop(self):
        goods_name = input("请输入需要卖出的商品名称:")
        ret = self.check(goods_name)
        if ret is not None:
            g_num = int(input("卖出个数:"))
            if ret.num - g_num < 0:
                print("该商品数量不足!请补充")
            else:
                old_goods = Goods(ret.name, ret.num - g_num, ret.cin, ret.cout)
                self.go.remove(ret)
                self.go.append(old_goods)
                gret = self.checkjs(goods_name)
                if gret is None:
                    shop_goods = gGoods(ret.name, g_num, ret.cin * g_num, ret.cout * g_num)
                    self.js.append(shop_goods)
                else:
                    shop_goods = gGoods(gret.name, g_num + gret.gnum, gret.gcin + ret.cin * g_num,
                                        gret.gcout + ret.cout * g_num)
                    self.js.remove(gret)
                    self.js.append(shop_goods)
                print("卖出后:", end=' ')
                old_goods = Goods(ret.name, ret.num - g_num, ret.cin * g_num, ret.cout * g_num)
                print(old_goods)
        else:
            print("没有此商品!")

    # 汇总当天卖出商品,包括每种销售商品名称、数量、进货总价、销售总价等。
    def Summary(self):

        for goods in self.js:
            print(goods)
        print("售出的物品进货总价:", end="")
        x = 0
        for goods in self.js:
            x += float(goods.gcin)

        print("售出的物品销售总价:", end="")
        y = 0
        for goods in self.js:
            y += float(goods.gcout)
        print(y)
        print("利润:", y - x)


if __name__ == '__main__':
    manager = GoodsManager()
    manager.Menu()

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
抱歉,作为AI语言模型,我无法提供本地代码。但是,您可以通过以下步骤来实现四则运算验证码识别: 1. 安装必要的 Python 库:PIL、numpy、tensorflow、keras 等。 2. 准备训练集和测试集:可以使用 Python 的 PIL 库生成大量的四则运算验证码图片。 3. 构建卷积神经网络(CNN)模型:使用 Keras 实现 CNN 模型,其中包括卷积层、池化层、全连接层等。 4. 训练模型:使用训练集对 CNN 模型进行训练,得到一个训练好的模型。 5. 测试模型:使用测试集对训练好的模型进行测试,并计算出模型的准确率。 6. 应用模型:将训练好的模型应用于实际的验证码识别场景中。 以下是一个简单的示例代码: ```python import numpy as np from PIL import Image import tensorflow as tf from tensorflow import keras # 构建 CNN 模型 model = keras.Sequential([ keras.layers.Conv2D(32, (3, 3), activation='relu', input_shape=(28, 28, 1)), keras.layers.MaxPooling2D((2, 2)), keras.layers.Conv2D(64, (3, 3), activation='relu'), keras.layers.MaxPooling2D((2, 2)), keras.layers.Flatten(), keras.layers.Dense(64, activation='relu'), keras.layers.Dense(10, activation='softmax') ]) # 编译模型 model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy']) # 加载训练集和测试集 train_images = np.load('train_images.npy') train_labels = np.load('train_labels.npy') test_images = np.load('test_images.npy') test_labels = np.load('test_labels.npy') # 对训练集进行归一化处理 train_images = train_images / 255.0 # 对测试集进行归一化处理 test_images = test_images / 255.0 # 训练模型 model.fit(train_images, train_labels, epochs=5) # 评估模型 test_loss, test_acc = model.evaluate(test_images, test_labels) print('Test accuracy:', test_acc) # 应用模型 image = Image.open('captcha.png') image = image.convert('L') image = image.resize((28, 28)) image = np.array(image) image = image.reshape(1, 28, 28, 1) image = image / 255.0 prediction = model.predict(image) print('Prediction:', np.argmax(prediction)) ``` 其中,train_images.npy、train_labels.npy、test_images.npy、test_labels.npy 是训练集和测试集的数据和标签,可以使用 numpy 库将它们保存为 .npy 文件。captcha.png 是待识别的验证码图片。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

*Melon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值