IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 每日练习题:开发图书管理系统 -> 正文阅读

[大数据]每日练习题:开发图书管理系统

需求

实现一个简单的图书管理系统,其中包含添加图书、修改图书、图书列表、查询图书、删除图书、借阅图书、归还图书功能。

数据库建表

CREATE TABLE `books`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `position` varchar(40) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `status` tinyint(1) UNSIGNED ZEROFILL NULL DEFAULT NULL,
  `borrorwer` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 16 CHARACTER SET = latin1 COLLATE = latin1_swedish_ci ROW_FORMAT = Dynamic;

代码实现

# !/usr/bin/env python
# -*-coding:utf-8 -*-

"""
# File       : BookMange.py
# Time       :2021/9/11 19:02
# Author     :YSQ
# version    :python 3.8
# Description:
"""

import pymysql


class DB:

    def __init__(self):

        self.con = pymysql.connect(
            user="root",
            password="",
            host="",
            port=3306,
            database=""
        )

        self.cur = self.con.cursor(cursor=pymysql.cursors.DictCursor)

    def query_sql(self, sql):
        """
        查询sql方法
        :param sql: sql语句
        :return: 返回查询的结果
        """

        self.cur.execute(sql)
        return self.cur.fetchall()

    def updata_sql(self, sql):
        """
        修改sql
        :param sql:
        :return:
        """

        self.cur.execute(sql)
        self.con.commit()

    def close(self):
        """
        关闭游标,断开链接
        :return:
        """
        self.cur.close()
        self.con.close()


class Books(object):

    def __init__(self):
        self.DB = DB()

    def add_book(self):
        """
        添加图书
        :return:
        """
        print("*************添加图书*************")
        name = input("请输入书名:")
        position = input("请输入图书存放的位置:")
        if name and position:
            sql = f'insert into books(name,position) value("{name}","{position}")'
            self.DB.updata_sql(sql)
            print("添加成功!")

            n = input("继续添加请输入1: 回车返回主菜单:")
            # 判断用户输入的是否为 1, 为 1 则调用自身,再次添加图书
            if n == "1":
                self.add_book()
        else:
            print("添加失败,书名或位置不能为空!")

    def update_book(self):
        """
        修改图书
        :return:
        """
        print("*************修改图书*************")
        id = input("请输入图书id:")
        # 判断查询的书籍 id 是否存在
        res = self.DB.query_sql(f"select * from books where id = {int(id)}")
        if res:
            print("当前图书的信息:", res)
            # 判断如果用户不输入图书名称,则使用之前的图书名称
            name = input("请输入书名,不修改输入回车:") or res[0]['name']
            position = input("请输入图书存放的位置, 不修改输入回车: ") or res[0]['position']
            sql = f'update books set name="{name}",position="{position}" where id={id}'
            self.DB.updata_sql(sql)
            print("修改成功!")
            n = input("继续修改请输入1, 回车返回主菜单:")
            if n == "1":
                self.update_book()

        else:
            print("您输入的书籍id不存在")

    def del_book(self):
        """
        删除图书
        :return:
        """
        print("***********删除图书***************")
        id = input("请输入删除图书的id:")
        # 判断删除的书籍 id 是否存在
        res = self.DB.query_sql(f"select * from books where id = {id}")
        if res:
            print("您要删除的信息如下:", res)
            is_delect = input("确认删除请输入1, 不删除请回车")
            if is_delect == "1":
                sql = f'delete from books where id={id}'
                self.DB.updata_sql(sql)
                print("删除成功!")

                # 判断是否要继续删除
                n = input("继续删除请输入1, 否则按回车:")
                if n == "1":
                    self.del_book()
        else:
            print("您输入的id对应的书籍不存在!")

    def query_book(self):
        """
        查询图书
        :return:
        """
        print("**************查询图书*****************")
        name = input("请输入您要查询的书籍名称:")

        sql = f'select * from books where name = "{name}"'
        res = self.DB.query_sql(sql)
        if res:
            for i in res:
                print(i)
            n = input("继续查询请输入1,否则回车")
            if n == "1":
                self.query_book()
        else:
            print("图书馆中暂无该书籍!")

    def book_list(self):
        """图书列表"""
        sql = "select * from books;"
        res = self.DB.query_sql(sql)
        for i in res:
            print(f"编号:{i['id']}, 书名:{i['name']}, 位置:{i['position']}, 状态:{i['status']}, 借阅人:{i['borrorwer']}")

    def revert_book(self):
        """归还图书"""
        id = input("请输入图书编号:")
        res = self.DB.query_sql(f"select * from books where id = {id}")
        if res:

            if res[0]['status'] != 2:
                print("该书籍当前为待出借状态,无需归还!")
            else:
                sql = f'update books set borrorwer = NULL, status=1 where id={id}'
                self.DB.updata_sql(sql)
                print("归还成功!")
                n = input("如需规划请输入1,否则按回车")
                if n == "1":
                    self.revert_book()

        else:
            print("规划的图书编号不存在!")

    def lend_book(self):
        """借阅图书"""
        print("**********借阅图书************")
        id = input("请输入借阅图书的编号id:")
        res = self.DB.query_sql(f"select * from books where id = {id}")
        # 判断借阅的书籍 id 是否存在
        if res:
            # 判断图书状态,如果状态为 2 被借阅,则无法出借
            if res[0]['status'] == 2:
                print("该书籍已被他人借阅!")
            else:
                print("您借阅的图书内容为:", res)
                name = input("请输入您的名称:")
                res = f"select * from books where borrorwer = '{name}'"
                lend_list = self.DB.query_sql(res)
                # 判断每人最多只能借阅5本书
                if len(lend_list) >= 5:
                    print("每人最多只能借阅5本书!")
                else:
                    sql = f'update books set borrorwer = "{name}",status=2 where id={id}'
                    self.DB.updata_sql(sql)
                    print("借阅成功!")
                    n = input("继续借阅请输入1,否则回车:")
                    if n == "1":
                        self.lend_book()
        else:
            print("您借阅的书籍不存在!")

    def quit(self):
        self.DB.close()
        print("程序已退出,欢迎下次使用~")

    def print_menu(self):
        """打印菜单"""
        print('-----------菜单------------')
        print("【1】:添加图书")
        print("【2】:修改图书")
        print("【3】:删除图书")
        print("【4】:查询图书")
        print("【5】:图书列表")
        print("【6】:出借图书")
        print("【7】:归还图书")
        print("【8】:退出")

    def main(self):
        print("************欢迎进入图书管理*****************")
        while True:
            self.print_menu()
            number = input("请输入你的选项:")
            if number == '1':
                self.add_book()
            elif number == '2':
                self.update_book()
            elif number == '3':
                self.del_book()
            elif number == '4':
                self.query_book()
            elif number == '5':
                self.book_list()
            elif number == '6':
                self.lend_book()
            elif number == '7':
                self.revert_book()
            elif number == '8':
                self.quit()
                break
            else:
                print("您输入的选项有误!")


if __name__ == '__main__':
    books = Books()
    books.main()

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-09-12 20:42:06  更:2021-09-12 20:42:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 13:44:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码