面向对象版学员管理系统(存储数据库)

面向对象版学员管理系统(存储数据库)数据库,面向对象

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

目标

  1. 了解⾯向对象开发过程中类内部功能的分析⽅法
  2. 了解常⽤系统功能
    1. 添加
    2. 删改
    3. 修改
    4. 查询

系统需求

使用面向对象编程思想完成学员管理系统的开发,具体如下:

  1. 系统要求:学员数据存储在数据库中
  2. 系统功能:添加学员,删除学员,修改学员信息,查询学员信息,显示所有学员信息

准备程序文件

1.分析

  1. 学员
  2. 管理系统

注意:为方便维护,一般一个角色一个程序文件,项目要有主程序入口,习惯为main.py

2.创建程序文件

程序文件如下:

  • 程序入口文件:main.py
  • 学员文件:student.py
  • 管理系统文件:managerSystem.py

书写程序

student.py

需求:

  • 学员信息包含:姓名、性别、⼿机号;
  • 添加 __str__ ⽅法,⽅便查看学员对象信息
class Student(object):
    def __init__(self, name, gender, tel):
        # 姓名、性别、手机号
        self.name = name
        self.gender = gender
        self.tel = tel

    def __str__(self):
        return f'{self.name}, {self.gender}, {self.tel}'

managerSystem.py

需求:

  • 存储数据的位置:数据库
    • 增删改查
  • 存储数据的形式
  • 系统功能
    • 添加
    • 删除
    • 修改
    • 查询
    • 显示所有信息
from student import *
import pymysql
#数据库名称
DBhost = 'localhost'
DBuser = 'root'
DBpassword = '*******'#数据库系统
DBname = 'dbtest'
class StudentManager(object):
    def __init__(self):
        # 存储学员数据 -- 列表
        self.student_list = ()
        #存储学员数据--数据库
        try:
            self.db = pymysql.connect(host=DBhost, user=DBuser, password=DBpassword, database=DBname)
            print("数据库连接成功!")
            self.cur = self.db.cursor()  # 声明一个游标

            # self.cur.execute('DROP TABLE IF EXISTS studentmassage')
            # # 用户输入姓名、性别、手机号
            # sql = "CREATE table studentmassage(Name char(20) NOT NULL,sex char(30),idcard char(20))"  # 表头标签 双引号!
            # self.cur.execute(sql)  # execute执行sql语句
        except pymysql.Error as a:
            print("数据库连接失败!" + str(a))
    # 一. 程序入口函数
    def run(self):
        # 1. 加载文件里面的学员数据
        self.load_student()
        while True:
            # 2. 显示功能菜单
            self.show_menu()
            # 3. 用户输入目标功能序号
            menu_num = int(input('请输入您需要的功能序号:'))

            # 4. 根据用户输入的序号执行不同的功能 -- 如果用户输入1,执行添加
            if menu_num == 1:
                # 添加学员
                self.add_student()
            elif menu_num == 2:
                # 删除学员
                self.del_student()
            elif menu_num == 3:
                # 修改学员信息
                self.modify_student()
            elif menu_num == 4:
                # 查询学员信息
                self.search_student()
            elif menu_num == 5:
                # 显示所有学员信息
                self.show_student()
            elif menu_num == 6:
                # 保存学员信息
                self.save_student()
            elif menu_num == 7:
                # 退出系统 -- 退出循环
                break

    # 二. 系统功能函数
    # 2.1 显示功能菜单 -- 打印序号的功能对应关系 -- 静态
    @staticmethod
    def show_menu():
        print('请选择如下功能:')
        print('1:添加学员')
        print('2:删除学员')
        print('3:修改学员信息')
        print('4:查询学员信息')
        print('5:显示所有学员信息')
        print('6:保存学员信息')
        print('7:退出系统')

    # 2.2 添加学员
    def add_student(self):
        # 1. 用户输入姓名、性别、手机号
        name = input('请输入您的姓名:')
        gender = input('请输入您的性别:')
        tel = input('请输入您的手机号:')

        # 2. 创建学员对象 -- 类 ?类在student文件里面  先导入student模块,再创建对象
        student = Student(name, gender, tel)
        sql1 = "insert into studentmassage(Name,sex,idcard)value(%s,%s,%s)"
        # 3. 将该对象添加到学员数据库
        value = (student.name,student.gender,student.tel)#添加信息
        #print(value)
        self.cur.execute(sql1,value)#执行语句
        self.db.commit()#数据提交

    # 2.3 删除学员
    def del_student(self):
        # 1. 用户输入目标学员姓名
        del_name = input('请输入要删除的学员姓名:')

        sql3 = "select Name from studentmassage" #按名字查询数据库
        self.cur.execute(sql3)
        results1 = self.cur.fetchall()#返回的名字的元组
        # print(results1)
        u=0#标志变量
        for ty in results1:#循环遍历
            name = ty[0]
            if name == del_name:#判断名字是否存在
                u=1
                sql2 = "delete from studentmassage where Name =%s"
                self.cur.execute(sql2, del_name)#删除名字的操作
                self.db.commit()
        if u==0:
            print("查无此人!")

    # 2.4 修改学员信息
    def modify_student(self):
        # 1. 用户输入目标学员姓名
        modify_name = input('请输入要修改的学员姓名:')
        sql3 = "select Name from studentmassage"
        self.cur.execute(sql3)
        results1 = self.cur.fetchall()
        u = 0
        for ty in results1:
            name = ty[0]
            if name == modify_name:
                u = 1
                sql2 = "delete from studentmassage where Name =%s"
                # newname = input("请输入新名字:")
                # newsex = input("请输入性别:")
                # newtel = input("请输入手机号:")
                self.cur.execute(sql2,modify_name)#删除姓名
                self.db.commit()
                self.add_student()#执行新添加
                break
        if u == 0:
            print("查无此人!")
        # 2. 遍历列表数据,如果学员存在修改姓名性别手机号,否则提示学员不存在
        # for i in self.student_list:
        #     if modify_name == i.name:
        #         i.name = input('姓名:')
        #         i.gender = input('性别:')
        #         i.tel = input('手机号:')
        #         print(f'修改学员信息成功,姓名{i.name}, 性别{i.gender}, 手机号{i.tel}')
        #         break
        # else:
        #     print('查无此人!')

    # 2.5 查询学员信息
    def search_student(self):
        # 1. 用户输入目标学员姓名
        search_name = input('请输入您要搜索的学员姓名:')
        sqlselect = "select * from studentmassage"
        self.cur.execute(sqlselect)
        results1 = self.cur.fetchall()  # 接收查询的信息,是一个元组
        #print(results1)
        # 2. 遍历列表。如果学员存在打印学员信息,否则提示学员不存在
        h=1
        for i in results1:
            name = i[0]
            gread = i[1]
            stuid = i[2]
            if search_name == name:
                print(f'姓名是{name}, 性别是{gread}, 手机号是{stuid}')
                h = 0

        if h==1:
            print('查无此人!')

    # 2.6 显示所有学员信息
    def show_student(self):
        sql4 = "select Name,sex,idcard from studentmassage"
        self.cur.execute(sql4)
        results2 = self.cur.fetchall()
        print(results2)
    # 2.7 保存学员信息
    def save_student(self):
        pass
    # 2.8 加载学员信息
    def load_student(self):
        pass



里面包含所有的功能,如果要添加功能需要自己定义def,然后在菜单页面添加相应操作

main.py

# 1. 导入管理系统模块
from managerSystem import *

# 2. 启动管理系统
# 保证是当前文件运行才启动管理系统:if --创建对象并调用run方法
if __name__ == '__main__':
    student_manager = StudentManager()
    student_manager.run()

总结

  • 函数
    • 定义和调用
    • 参数的使用
  • 面向对象
    • 定义类
    • 创建对象
    • 定义和调用实例属性
    • 定义和调用实例方法
  • 数据类型
    • 数据库形式存储
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/193710.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 接口定义

    接口定义1、什么是接口接口一般来讲分为两种程序内部的接口:方法与方法、模块与模块之间的交互,程序内部抛出的接口,如登录发帖,发帖就必须要登录,如果不登录不能发帖,发帖和登录这两个模块之间就要有交互,就会抛

    2022年7月1日
    28
  • 反转每对括号间的子串java_已知入栈序列求出栈序列

    反转每对括号间的子串java_已知入栈序列求出栈序列给出一个字符串 s(仅含有小写英文字母和括号)。请你按照从括号内到外的顺序,逐层反转每对匹配括号中的字符串,并返回最终的结果。注意,您的结果中 不应 包含任何括号。示例 1:输入:s = “(abcd)”输出:“dcba”示例 2:输入:s = “(u(love)i)”输出:“iloveu”示例 3:输入:s = “(ed(et(oc))el)”输出:“leetcode”示例 4:输入:s = “a(bcdefghijkl(mno)p)q”输出:“apmnolkjihgfedcb

    2022年8月9日
    1
  • 倒立摆模型分析_倒立摆系统建模方法

    倒立摆模型分析_倒立摆系统建模方法模型对小车的水平受力分析Mx¨=F−bx˙−NM\ddot{x}=F-b\dot{x}-NMx¨=F−bx˙−Nx¨\ddot{x}x¨代表对运动距离的二阶微分,即小车在外力作用下的加速度。FFF是外部施加给系统的外力。x˙\dot{x}x˙代表小车当前的运动速度,小车所受到的摩擦力为摩擦系数与小车运动速度之积,即f=bx˙f=b\dot{x}f=bx˙。NNN为倒单摆作用给小车水平方向的力。对倒单摆的受力分析摆杆做平面运动,可以分解为质心的平动和绕质心的转动。N=mx¨−(mlψ

    2022年8月18日
    4
  • ASP也做工作流

    ASP也做工作流

    2021年8月7日
    61
  • JSONObject使用方法详解

    JSONObject使用方法详解/***项目名称:tools*项目包名:com.songfayuantools.json*创建时间:2017年7月31日上午11:58:51*创建者:Administrator-宋发元*创建地点:*/packagecom.songfayuantools.json;importcom.songfayuantools.entity.UserInfo;im

    2022年7月13日
    12
  • spss聚类分析步骤详细解读_spss聚类分析实验报告

    spss聚类分析步骤详细解读_spss聚类分析实验报告目录快速聚类系统聚类分析二阶聚类分析快速聚类【分析】【分类】【k-均值聚类】,将变量移至变量框中,员工id移至【个案标注依据】框中【聚类数】是期望分成几组【保存】勾选【聚类成员】复选框结果解读:随机选择三个数据作为快速聚类的初始位置显示迭代次数,迭代过程可以理解为每个类别与初始位置之间的距离改变情况,当这个距离变动非常小,迭代就完成了…

    2022年10月9日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号