Python学生管理系统(三)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Python学生管理系统(三)

Python的学生管理系统第三版——学生管理系统链接数据库(Mysql)!!!


今天带来一个新的python的一个库——pymysql(链接Mysql数据库)


如果对这个库有点陌生或者不熟练的我把这个库的教程放在下面,大家有时间可以去看看,如果有不会的或者哪个地方不太懂也可以直接和我讨论哦!!!


请看这里哦——pymysql使用学习。


接下来直接上代码了!!!!


import pymysql
name_list = []
#登录数据库
def get_connect():
    conn = pymysql.connect(host='localhost', user="root", passwd='自己的密码',database='stu')
    return conn
#主页面
def mune():
    print("-" * 30)
    print("   学生管理系统  v8.8  ")
    print("1.添加学生信息")
    print("2.删除学生信息")
    print("3.修改学生信息")
    print("4.查询单个学生信息")
    print("5.查询所有学生信息")
    print("0.退出系统")
    print("-" * 30)
#获取序号
def xh():
    x = int(input('请输入序号:'))
    return x
#增加学生信息
def add_s():
    new_info = {}
    new_id = input('请输入学号:')
    new_info['学号'] = int(new_id)
    new_name  = input('请输入姓名:')
    new_info['姓名'] = new_name
    new_sex = input('请输入性别:')
    new_info['性别'] = new_sex
    new_ihpone = input('请输入电话号码:')
    new_info['电话'] = new_ihpone
    add_sql(new_info)
    name_list.append(new_info)
#删除学生信息
def del_s():
    del_id = int(input('请输入要删除的学生号: '))
    for i in range(len(name_list)):
        if name_list[i]['学号'] == del_id:
            name_list.pop(i)
            del_sql(del_id)
            break
    else:
            print('没有该学生! ')
def search_stu():
    name = input('请输入学生姓名:')
    for i in range(len(name_list)):
        if name_list[i]['姓名'] == name:
            print(name_list[i])
            search_sql(name)
            break
    else:
            print('查无此人!')
def x_lsit():
    print('*' * 10)
    print('1.修改姓名!')
    print('2.修改性别!')
    print('3.修改电话!')
    print('*' * 10)
    z = int(input('请输入功能序号:'))
    def x_id():
        id = int(input('请输入学号:'))
        name = input('请输入新姓名:')
        f = False
        for i in range(len(name_list)):
            if name_list[i]['学号'] == id :
                name_list[i]['姓名'] = name
                f =True
        if f == True:
            print('修改成功!')
        else:
            print('修改失败!')
        x_sql(1, id)
    def x_xb():
        id = int(input('请输入学号:'))
        sex_id = input('请输入新性别:')
        f = False
        for i in range(len(name_list)):
            if name_list[i]['学号'] == id:
                name_list[i]['性别'] = sex_id
                f = True
        if f == True:
            print('修改成功!')
        else:
            print('修改失败!')
        x_sql(2,id)
    def x_dh(z):
        id = int(input('请输入学号:'))
        dh_id = input('请输入新性别:')
        f = False
        for i in range(len(name_list)):
            if name_list[i]['学号'] == id:
                name_list[i]['电话'] = dh_id
                f = True
        if f == True:
            print('修改成功!')
        else:
            print('修改失败!')
        x_sql(3, id)
    if z == 1:
        x_id()
    elif z == 2:
        x_xb()
    elif z == 3 :
        x_dh()
#在数据库中增加学生信息
def add_sql(stu):
    connection = get_connect()
    cur = connection.cursor(cursor=pymysql.cursors.DictCursor)
    sql = 'insert into student(学号,姓名,性别,电话) values("%s","%s","%s", "%s")'
    sid = stu['学号']
    name = stu['姓名']
    sex = stu['性别']
    iphone = stu['电话']
    try:
        cur.execute(sql%(sid,name,sex,iphone))
        connection.commit()
    except Exception as e:
        connection.rollback()
        raise e
    finally:
        connection.close()
#删除数据库中的学生信息
def del_sql(id):
            connection = get_connect()
            cur = connection.cursor()
            sql = 'delete from student where 学号 = %s '
            try:
                cur.execute(sql%id)
                connection.commit()
            except Exception as e:
                connection.rollback()
                raise e
            finally:
                connection.close()
#查询数据库中的单个
def search_sql(name):
    connection = get_connect()
    cur = connection.cursor()
    sql = 'select * from student where 姓名 ="%s"'
    cur = connection.cursor(cursor=pymysql.cursors.DictCursor)
    cur.execute(sql%name)
    f = cur.fetchall()
    print(f)
    connection.commit()
    cur.close()
    connection.close()
#查询所有学生信息
def search_all():
    connection = get_connect()
    cur = connection.cursor()
    sql = 'select * from student ; '
    #转化字典通格式用
    cur = connection.cursor(cursor=pymysql.cursors.DictCursor)
    cur.execute(sql)
    f = cur.fetchall()
    for i in f:
        # print(i)
        name_list.append(i)
    connection.commit()
    cur.close()
    connection.close()
#对数据库信息的修改
def x_sql(z,xsh):
    conn = pymysql.connect(host='localhost', user="root", passwd="自己的密码", database='数据库名称')
    cur = conn.cursor()
    def xname(xsh):
        # xh = int(input('学号:'))
        name = input('确认姓名:')
        arg = (name, xsh)
        sql = "update  student set 姓名 = '%s' where 学号 = %s "
        result = cur.execute(sql % arg)
        print(result)
        if result == 1:
            print('修改成功!')
        else:
            print('修改失败!')
        conn.commit()
        cur.close()
        conn.close()
    def xsex(xsh):
        # xh = int(input('学号:'))
        sex = input('确认性别:')
        arg = (sex, xsh)
        sql = "update  student set 性别 = '%s' where 学号 = %s "
        result = cur.execute(sql % arg)
        print(result)
        if result == 1:
            print('修改成功!')
        else:
            print('修改失败!')
        conn.commit()
        cur.close()
        conn.close()
    def xiphone(xsh):
        # xh = int(input('学号:'))
        iphone = int(input('确认新电话:'))
        arg = (iphone, xsh)
        sql = "update  student set 电话 = %s where 学号 = %s "
        result = cur.execute(sql % arg)
        if result == 1:
            print('修改成功!')
        else:
            print('修改失败!')
        conn.commit()
        cur.close()
        conn.close()
    def zhu(z):
        # n = int(input('请输入功能序号:'))
        if z == 1:
            xname(xsh)
        elif z == 2:
            xsex(xsh)
        elif z == 3:
            xiphone(xsh)
    zhu(z)
def main(x):
    if x == 1:
        add_s()
    elif x  ==2:
        del_s()
    elif x== 3 :
        x_lsit()
    elif x ==4:
        search_stu()
    elif x == 5:
       #search_all()
        for i in name_list:
            print(i)
search_all()
while 1:
 mune()
 x = xh()
 main(x)
 # print(name_list)
 if x ==0:
     break

虽然代码有点长还是不难理解的,这个是我一个月前写出来的,可能有些地方不是很完善,比如mysql的注入(应该解决了),非常希望大家来指正和谈论哦。


接下来看成果!!!

image.png


image.png


删除这个地方可以对比一下!!!!


image.png




相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
眼疾识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了4种常见的眼疾图像数据集(白内障、糖尿病性视网膜病变、青光眼和正常眼睛) 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,实现用户上传一张眼疾图片识别其名称。
135 5
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
|
2月前
|
机器学习/深度学习 人工智能 算法
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
356 55
|
1月前
|
安全 前端开发 数据库
Python 语言结合 Flask 框架来实现一个基础的代购商品管理、用户下单等功能的简易系统
这是一个使用 Python 和 Flask 框架实现的简易代购系统示例,涵盖商品管理、用户注册登录、订单创建及查看等功能。通过 SQLAlchemy 进行数据库操作,支持添加商品、展示详情、库存管理等。用户可注册登录并下单,系统会检查库存并记录订单。此代码仅为参考,实际应用需进一步完善,如增强安全性、集成支付接口、优化界面等。
|
3月前
|
机器学习/深度学习 数据采集 供应链
使用Python实现智能食品安全追溯系统的深度学习模型
使用Python实现智能食品安全追溯系统的深度学习模型
99 4
|
7天前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的【蘑菇识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
蘑菇识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了9种常见的蘑菇种类数据集【"香菇(Agaricus)", "毒鹅膏菌(Amanita)", "牛肝菌(Boletus)", "网状菌(Cortinarius)", "毒镰孢(Entoloma)", "湿孢菌(Hygrocybe)", "乳菇(Lactarius)", "红菇(Russula)", "松茸(Suillus)"】 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,
51 11
基于Python深度学习的【蘑菇识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
|
2月前
|
存储 缓存 监控
局域网屏幕监控系统中的Python数据结构与算法实现
局域网屏幕监控系统用于实时捕获和监控局域网内多台设备的屏幕内容。本文介绍了一种基于Python双端队列(Deque)实现的滑动窗口数据缓存机制,以处理连续的屏幕帧数据流。通过固定长度的窗口,高效增删数据,确保低延迟显示和存储。该算法适用于数据压缩、异常检测等场景,保证系统在高负载下稳定运行。 本文转载自:https://www.vipshare.com
132 66
|
2月前
|
机器学习/深度学习 人工智能 算法
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
宠物识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了37种常见的猫狗宠物种类数据集【'阿比西尼亚猫(Abyssinian)', '孟加拉猫(Bengal)', '暹罗猫(Birman)', '孟买猫(Bombay)', '英国短毛猫(British Shorthair)', '埃及猫(Egyptian Mau)', '缅因猫(Maine Coon)', '波斯猫(Persian)', '布偶猫(Ragdoll)', '俄罗斯蓝猫(Russian Blue)', '暹罗猫(Siamese)', '斯芬克斯猫(Sphynx)', '美国斗牛犬
220 29
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
|
1月前
|
机器学习/深度学习 算法 前端开发
基于Python深度学习果蔬识别系统实现
本项目基于Python和TensorFlow,使用ResNet卷积神经网络模型,对12种常见果蔬(如土豆、苹果等)的图像数据集进行训练,构建了一个高精度的果蔬识别系统。系统通过Django框架搭建Web端可视化界面,用户可上传图片并自动识别果蔬种类。该项目旨在提高农业生产效率,广泛应用于食品安全、智能农业等领域。CNN凭借其强大的特征提取能力,在图像分类任务中表现出色,为实现高效的自动化果蔬识别提供了技术支持。
基于Python深度学习果蔬识别系统实现
|
1月前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
32 3
|
2月前
|
机器学习/深度学习 算法 前端开发
基于Python深度学习的果蔬识别系统实现
果蔬识别系统,主要开发语言为Python,基于TensorFlow搭建ResNet卷积神经网络算法模型,通过对12种常见的果蔬('土豆', '圣女果', '大白菜', '大葱', '梨', '胡萝卜', '芒果', '苹果', '西红柿', '韭菜', '香蕉', '黄瓜')图像数据集进行训练,最后得到一个识别精度较高的模型文件。再基于Django框架搭建Web网页端可视化操作界面,以下为项目实现介绍。
69 4
基于Python深度学习的果蔬识别系统实现

热门文章

最新文章

推荐镜像

更多