Python怎么连接Mysql实现图书借阅系统

数据库的表结构

我们在这里需要三张表,一张用户表,一张图书表和一张借阅表。注意我们的数据库命名为bbs(book borrow system)

1.用户表

Python怎么连接Mysql实现图书借阅系统

2.图书表

Python怎么连接Mysql实现图书借阅系统

立即学习“Python免费学习笔记(深入)”;

bookname:书名author:作者booknum:图书编号bookpress:出版社bookamoun:图书数量

3.借阅表

九歌 九歌

九歌–人工智能诗歌写作系统

九歌 322 查看详情 九歌

Python怎么连接Mysql实现图书借阅系统

id:借阅号
borrowname:借阅人
borrowbook:借阅图书
bookid:图书编号同图书表booknum
borrowamoun:借阅数量
borrowdate:借阅日期
borrowback:归还日期

Python程序

1.主程序:图书借阅系统.py

# _*_ coding:utf-8 _*_import pymysqlimport db_eventimport book_managewhile True:    print("欢迎使用图书借阅系统\          [1]登陆 [2]注册 [3]退出")    choice = int(input("请输入您要进行的操作(数字):"))    if choice == 1:        name = input("请输入用户名:")        login_status=db_event.user_login(name)        if login_status==1:            book_manage.manage(name)        else:            print("登陆失败")            continue    elif choice==2:        create_user = db_event.user_create()        print("用户创建成功,您创建的用户信息如下:/n\              姓名:%s 年龄:%d 性别:%s 密码:%s" % (create_user[0], create_user[1], create_user[2], create_user[3]))    elif choice==3:        exit()    else:        print("无效操作!")        continue

2.图书的管理信息:book_manage.py

import db_eventdef manage(name):    while True:        print("欢迎进入图书系统\n\    [1]查询图书 [2] 借阅图书 [3]捐赠图书 [4]归还图书 [5]退出")        num = int(input('输入您的选择:'))        if num == 1:            db_event.book_select()        elif num == 2 :            chos=int(input("请选择[1]借阅 [2]续借 [3]查询借阅信息 [4]退出"))            if chos==1:                db_event.book_borrow(name)            elif chos==2:                db_event.borrow_again()            elif chos==3:                db_event.borrow_info_select(name)            elif chos==4:                continue            else:                print("无效操作")        elif num == 3 :            db_event.book_juanzeng()        elif num == 4 :            db_event.book_back()        elif num == 5 :            break        else:            print("无效输入!")

3.数据库的操作:db_event.py

# _*_ coding:utf-8 _*_import pymysqlimport randomimport stringdef user_login(name):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql = "SELECT name,mima FROM user WHERE name='%s'" %(name)    cursor.execute(sql)    results = cursor.fetchall()    if results:        res=results[0]        for i in range(3):            mima = input("请输入密码:")            if mima == res[1]:                print("登陆成功!")                login_status = 1                break            else:                login_status=0                print("密码输入不正确!请重新输入")        # print(login_status)        if login_status == 1 :            return login_status        else:            print("您已输入错误密码三次,无法登陆图书借阅系统,欢迎下次使用!")            login_status = 0            return login_status    else:        login_status = 0        print("您输入的用户不存在!")        return login_status    db.close()#判断是否登陆成功,1为成功,0为不成功# login_status=user_login()# if login_status==1:#     print("ok")# else:#     print("no")#关闭数据库连接# curcor.close()# db.close()def user_create():    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    name=input("请输入姓名:")    age=int(input("请输入年龄:"))    sex=input("请输入性别[M]男 [W]女 :")    mima=input("为您的用户设置一个8位数密码:")    sql = "INSERT INTO user VALUES('%s',%s,'%s','%s')" %(name,age,sex,mima)    cursor.execute(sql)    db.commit()    sql1="SELECT * FROM user WHERE name='%s'" %(name)    cursor.execute(sql1)    results=cursor.fetchone()    return results    db.close()#create_user=user_create()#print("用户创建成功,您创建的用户信息如下:/n\ #     姓名:%s 年龄:%d 性别:%s 密码:%s" %(create_user[0],create_user[1],create_user[2],create_user[3]))def book_info_select(x,y):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql = "SELECT * FROM book WHERE %s='%s'" %(x,y)    cursor.execute(sql)    results=cursor.fetchone()    if results:        print("书名:%s 作者:%s 书籍编号:%s 出版社:%s 剩余数量:%d " %(results[0],results[1],results[2],results[3],results[4]))    else:        print("没有您所要查询的图书")    db.close()def book_select():    a = int(input("输入您要查询的图书关键信息\            [1]书名 [2]作者 [3]书籍号 [4]出版社"))    b=""    if a == 1 :        b="bookname"        name=input("请输入要查询的书名:")        book_info_select(b,name)    elif a == 2 :        b="author"        auth=input("请输入作者名:")        book_info_select(b,auth)    elif a == 3 :        b="booknum"        num=input("请输入书籍编号")        book_info_select(b,num)    elif   a == 4 :        b="bookpress"        press=input("请输入出版社:")        book_info_select(b,press)    else:        print("输入有误")        book_select()def gen_code(len=8):    code_str = string.ascii_letters + string.digits    return ''.join(random.sample(code_str, len))def book_add(name,auth,press,amount):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    num=gen_code()    sql = "INSERT INTO book VALUES('%s','%s','%s','%s',%s)" %(name,auth,num,press,amount)    sql1 = "SELECT booknum FROM book"    cursor.execute(sql1)    res = cursor.fetchall()    list=[]    for i in res :        list.append(i)    try:        while True:            if num in list:                gen_code()            else:                cursor.execute(sql)                db.commit()                print("图书捐赠成功,谢谢您!")                break    except:        print("输入图书数目错误!")        db.rollback()    db.close()def book_update_add(name,auth,press,amount):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql="UPDATE book SET bookamount=bookamount+%s WHERE bookname='%s' AND author='%s' AND bookpress='%s'" %(amount,name,auth,press)    try:        cursor.execute(sql)        db.commit()        print("图书捐赠成功,谢谢您!")    except:        print("输入图书数目错误!")        db.rollback()    db.close()def book_juanzeng():    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    name=input("请输入您要捐赠的图书书名:")    auth=input("请输入您要捐赠的图书作者:")    press=input("请输入您要捐赠的图书的出版社:")    amount = int(input("输入您要捐赠的数目:"))    sql = "SELECT * FROM book WHERE bookname='%s'AND author='%s' AND bookpress='%s'" %(name,auth,press)    cursor.execute(sql)    results=cursor.fetchone()    if results:        book_update_add(name,auth,press,amount)    else:        book_add(name,auth,press,amount)    db.close()def book_if_borrow(booknum,amount):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql = "SELECT bookamount FROM book WHERE booknum='%s'" %(booknum)    cursor.execute(sql)    res = cursor.fetchall()    if res:        if res[0][0] >= amount :    #编号为booknum的书的数量还有,可以借            return True        else:            print("您所需要的编号为%s的书籍当前图书馆只有%d本,不满足您的需求" %(booknum,res[0][0]))            return False    else:        print("查无此书,请确认您的书籍编号!")        return False    db.close()def book_borrow_after(amount,booknum):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql = "UPDATE book SET bookamount=bookamount-%s WHERE booknum='%s'" %(amount,booknum)    cursor.execute(sql)    db.commit()    db.close()def borrow_add(name,booknum,amount):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    days = int(input("请输入您选择借阅的天数(不可超过365天):"))    sql = "INSERT INTO borrow VALUES(NULL,'%s',(SELECT bookname FROM book WHERE booknum='%s'),'%s',%s,CURDATE(),DATE_ADD(CURDATE(),INTERVAL %s DAY))" %(name,booknum,booknum,amount,days)    cursor.execute(sql)    db.commit()def select_after_borrow(booknum,name):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql2 = "SELECT * FROM borrow WHERE bookid='%s' AND borrowname='%s'" % (booknum, name)    cursor.execute(sql2)    return cursor.fetchall()def book_borrow(name):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    booknum=input("请输入您要借阅的图书编号:")    amount=int(input("请输入您要借阅的书籍个数:"))    sql1 = "SELECT * FROM book WHERE booknum='%s'" % (booknum)    cursor.execute(sql1)    result = cursor.fetchone()    res = book_if_borrow(booknum,amount)    if res:        print("您要借阅的书籍书名:%s 作者:%s 书籍编号:%s 出版社: %s 当前剩余:%d本 借后剩余:%d本" %(result[0],result[1],result[2],result[3],result[4],result[4]-amount))        book_borrow_after(amount,booknum)        #db.commit()        borrow_add(name,booknum,amount)        info=select_after_borrow(booknum,name)        print("以下是您的借阅图书信息,注意借阅号,这将是您还书的凭证!\n\借阅号:%d 借阅人:%s 借阅图书:%s 图书编号:%s 借阅数量:%d 借阅日期:%s 归还日期:%s" %(info[-1][0],info[-1][1],info[-1][2],info[-1][3],info[-1][4],info[-1][5],info[-1][6]))        print("借阅成功")        while True:            a=int(input("请输入您选择:[1]继续借阅 [2]退出"))            if a == 1:                book_borrow(name)                break            elif a == 2 :                break            else:                print("无效操作")    else:        print("借阅失败")        while True:            a=int(input("请输入您选择:[1]继续借阅 [2]退出"))            if a == 1:                book_borrow(name)                break            elif a == 2 :                break            else:                print("无效操作")    db.close()def back_if_over(id):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql = "SELECT * FROM borrow WHERE backdate >= CURDATE() AND id = %s" %(id)    cursor.execute(sql)    res=cursor.fetchall()    if res:        return True    else:        return False    db.close()def book_back_update(id):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql = "UPDATE book SET bookamount=bookamount+(SELECT borrowamount FROM borrow WHERE id = %s) WHERE booknum=(SELECT bookid FROM borrow WHERE id = %s)" %(id,id)    cursor.execute(sql)    db.commit()    db.close()def borrow_back_update(id):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql = "DELETE FROM borrow WHERE id=%s" %(id)    cursor.execute(sql)    db.commit()    db.close()def book_back():    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    while True:        id = int(input("请输入您的借阅号:"))        sql1 = "SELECT * FROM borrow WHERE id=%s" %(id)        cursor.execute(sql1)        info =cursor.fetchone()        if info:            print("以下是您的借阅图书信息,注意借阅号,这将是您还书的凭证!\n\借阅号:%d 借阅人:%s 借阅图书:%s 图书编号:%s 借阅数量:%d 借阅日期:%s 归还日期:%s" % (info[0], info[1], info[2], info[3], info[4], info[5], info[6]))            choice=int(input("请确认您的归还借书信息:[1]确认 [2]返回 [3]退出"))            if choice == 1 :                #判断是否逾期:                if back_if_over(id):                    book_back_update(id)                    borrow_back_update(id)                    print("还书成功")                    break                else:                    print("您已逾期,请联系管理员!")                    break            elif choice == 2:                continue            elif choice == 3 :                break            else:                print("无效输入")        else:            print("请输入正确的借阅号")def borrow_info_again(id,day):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql1 = "SELECT * FROM borrow WHERE id=%s" % (id)    cursor.execute(sql1)    info = cursor.fetchone()    print("以下是您的借阅图书信息:\n\借阅号:%d 借阅人:%s 续借天数:%d 借阅图书:%s 图书编号:%s 借阅数量:%d 初始借阅日期:%s 归还日期:%s" %(info[0], info[1],day,info[2], info[3], info[4], info[5], info[6]))    db.close()def borrow_update_again(id):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    a=int(input("请输入您的续借天数(不超过31天):"))    if a > 31 :        print("您的借阅天数已超过系统权限,如要借阅,请联系管理员!")    else:        sql="UPDATE borrow SET backdate=DATE_ADD(backdate,INTERVAL %s DAY) WHERE id=%s" %(a,id)        cursor.execute(sql)        db.commit()        db.close()    return adef borrow_again():    id=int(input("输入您的借阅号:"))    if back_if_over(id):        day=borrow_update_again(id)        borrow_info_again(id,day)        print("续借成功")    else:        print("您已逾期,请先联系管理员再进行操作,谢谢!")def borrow_info_select(name):    db = pymysql.connect("localhost", "ljz", "redhat", "bbs")    cursor = db.cursor()    sql = "SELECT * FROM borrow WHERE borrowname='%s'" %(name)    cursor.execute(sql)    res=cursor.fetchall()    if res:        for i in range(len(res)):            print("以下是您的第%d条借阅图书信息:\n\借阅号:%d 借阅人:%s 借阅图书:%s 图书编号:%s 借阅数量:%d 借阅日期:%s 归还日期:%s" % (i+1,res[i][0], res[i][1], res[i][2], res[i][3], res[i][4], res[i][5], res[i][6]))    else:        print("您没有借阅图书")    db.close()

以上就是Python怎么连接Mysql实现图书借阅系统的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1029577.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
讯飞火星AI如何进行古诗词赏析辅助_讯飞火星AI古诗文理解与赏析功能使用方法
上一篇 2025年12月2日 03:03:45
Java应用中SQL操作性能基准测试指南
下一篇 2025年12月2日 03:03:53

相关推荐

  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    100
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • Python递归函数追踪与性能考量:以序列打印为例

    本文深入探讨了Python中一种递归打印序列元素的方法,并着重演示了如何通过引入缩进参数来有效追踪递归函数的执行流程和参数变化。通过实际代码示例,文章揭示了递归调用可能带来的潜在性能开销,特别是对调用栈空间的需求,以及Python默认递归深度限制可能导致的错误,为读者提供了理解和优化递归算法的实用见…

    2026年5月10日
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • Python中怎样使用pymongo?

    在python中使用pymongo可以轻松地与mongodb数据库进行交互。1)安装pymongo:pip install pymongo。2)连接到mongodb:from pymongo import mongoclient; client = mongoclient(‘mongod…

    2026年5月10日
    000
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000
  • Python 函数参数类型:如何使用可变参数和动态参数?

    python 中的参数类型:关键词参数、可变参数和动态参数 在 python 中,函数的参数可以分为以下几种类型: 关键词参数(kw)**:这些参数具有名称,并且在调用函数时明确指定。可变参数(*args):这些参数没有名称,允许函数接受任意数量的位置参数。它们将被收集到一个元组中。动态参数(kwa…

    2026年5月10日
    000
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • python中numpy的用法

    NumPy是Python中用于科学计算的强大库,它提供了以下功能:多维数组处理矩阵运算快速傅里叶变换(FFT)线性代数随机数生成 NumPy在Python中的强大功能 NumPy是Python中用于科学计算的一个强大且灵活的库。它提供了用于处理多维数组和矩阵的一组高效工具,是数据分析和机器学习项目的…

    2026年5月10日
    100
  • python如何捕获所有类型的异常_python try except捕获所有异常的方法

    答案:捕获所有异常推荐使用except Exception as e,可捕获常规错误并记录日志,避免影响程序正常退出;需拦截系统信号时才用except BaseException as e。 在Python中,要捕获所有类型的异常,最常见且推荐的方法是使用 except Exception as e…

    2026年5月10日
    000
  • python中f怎么用

    f-字符串是 Python 3.6 中引入的格式化字符串语法糖,提供了简洁且安全的方式来插入表达式和变量。f-字符串以字符串前缀 f 为标志,使用大括号包含表达式或变量。f-字符串支持条件表达式和格式规范符,提供了更大的灵活性、安全性、可读性和易维护性。 在 Python 中使用 f-字符串 f-字…

    2026年5月10日
    100
  • 怎么在手机上把XML文件转换为PDF?

    不可能直接在手机上用单一应用完成 XML 到 PDF 的转换。需要使用云端服务,通过两步走的方式实现:1. 在云端转换 XML 为 PDF,2. 在手机端访问或下载转换后的 PDF 文件。 怎么在手机上把XML文件转换为PDF? 这问题问得好,比直接问“怎么转换”有深度多了!因为它触及了移动端环境的…

    2026年5月10日
    000
  • ReCAPTCHA V3低分处理策略:结合V3与V2实现智能风险控制与用户验证

    本文旨在解决ReCAPTCHA V3在低分情况下无法直接触发验证码挑战的问题。我们将探讨如何通过巧妙地结合ReCAPTCHA V3的无感评分机制与ReCAPTCHA V2的交互式挑战,实现一套既能有效阻挡机器人流量,又能最大限度减少对合法用户干扰的智能验证系统。文章将详细阐述其实现原理、前端与后端集…

    2026年5月10日
    100
  • Python正则表达式:处理数字不同情况的替换

    本文旨在帮助读者理解和解决在使用Python正则表达式进行数字替换时遇到的问题。通过具体示例,详细解释了如何正确匹配和替换不同格式的数字,避免常见的匹配陷阱,并提供可直接使用的代码示例。掌握这些技巧,能有效提高处理文本数据的效率和准确性。 在使用Python的re模块进行字符串替换时,正则表达式的编…

    2026年5月10日
    000
  • python的tuple什么意思

    元组是Python中一种有序、不可变的序列数据结构。用于存储相关数据,例如坐标、个人信息或枚举值。创建方式:圆括号(),元素以逗号,分隔。访问元素:索引运算符;遍历元素:for循环。 什么是Python中的Tuple? Tuple,中文称为元组,是Python中一种有序、不可变的序列数据结构。 特点…

    2026年5月10日
    000
  • Python官网用户调查的参与方式_Python官网反馈提交详细教程

    答案是通过访问Python官网新闻页面、邮件邀请链接或GitHub仓库提交反馈。具体为:访问官网查找用户调查公告,或点击邮件中的专属链接参与,在GitHub的cpython仓库提交技术建议,并注意如实填写问卷与保护隐私。 如果您希望参与Python官网的用户调查并提交反馈,可以通过官方指定的渠道完成…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信