python实现简易图书管理系统

本文实例为大家分享了python实现简易图书管理系统的具体代码,供大家参考,具体内容如下

一、设计需求

1.添加书籍
2.查询数据
3.借书

存储方式 ,用excel保存到硬盘上或者用.txt文件保存

二、实现代码

1.用excel存储

# 一、介绍
# 主要功能实现
# 1、借书
# 2、添加新书
# 3、查找图书

# 数据存储:excel表

import xlwt
import xlrd
import xlutils.copy
import os

#book = {"位置":"","书名":"","价格":"","作者":""}
#存储方式  用excel
title =["位置","书名","价格","作者"]

#查看当前的书本数,也就行号
def read_book_num():
    path = os.path.join(os.getcwd()+r'\图书.xls')
    print(path)
    flag = os.path.exists(path)
    if(flag):
        book_excel = xlrd.open_workbook("图书.xls")
        sheet1 = book_excel.sheets()[0]
        book_num = sheet1.nrows
    else:
        book_num = 0
    return book_num

def add_book(book_num):
    #判断excel是否存在,如果不存在,就创建
    path = os.path.join(os.getcwd()+r'\图书.xls')
    flag = os.path.exists(path)
    print("flag",flag)
    if(flag):
        #如果存在,就打开excel
        book_excel = xlrd.open_workbook("图书.xls") 
        #并复制之前的已经存在的数据
        book_excel = xlutils.copy.copy(book_excel)
        sheet1 = book_excel.get_sheet(0)
        #sheet1 = book_excel.sheets()[0]

    else:
        book_excel = xlwt.Workbook("图书.xls") #新建excel
        sheet1 = book_excel.add_sheet(sheetname="图书表单",cell_overwrite_ok=True)
    while(1):
        #打印提示
        button_num = input("请选择你的操作\n:"+"1.添加新书\n"+"2.退出请按q\n")
        if(button_num == 'q'):
            break
        elif (button_num == "1"):
            #输入一本书的所有信息,并且先存储到book里面
            book = []  #清空书本信息
            input_value = '' #清空输入
            for i in range(4):
                print("请输入:",title[i])
                input_value = input()
                book.append(input_value)
            #存储到硬盘(将输入的数据存储到excel中)
            for i in range(4):
                #写入第book_num行数据
                sheet1.write(book_num,i,book[i])
            book_num = book_num +1 #总书数量加1
            book_excel.save("图书.xls")
            print("添加成功")
        else:
            print("输入无效,请重新输入!")

def search_book():
    #打开excel
    book_excel = xlrd.open_workbook("图书.xls")
    sheet1 = book_excel.sheets()[0]
    book_num = sheet1.nrows
    while(1):
        #输入书名 
        chose= input("请输入你的操作:\n"+"1.查询书籍:\n"+"2.退出请按q\n")
        if(chose == 'q'):
            break
        elif (chose == '1'):
            bookname = input("请输入书名:")
            for i in range(0,book_num):
                if(bookname == sheet1.cell(i,0).value):
                    print("查询成功,查询结果为\n",sheet1.row_values(i))
                    return
            else:
                print("查询失败,本书库没有此书")
                return
        else:
            print("操作有误,请重新输入!")

def borrow_book():
    #打开excel
    book_excel = xlrd.open_workbook("图书.xls")
    sheet1 = book_excel.sheets()[0]
    book_num = sheet1.nrows

    book_excel_copy = xlutils.copy.copy(book_excel)
    sheet1_copy = book_excel_copy.get_sheet(0)
    
    #重新创建一个excel,用于保存更新后的数据
    # book_excel_new = xlwt.Workbook("图书.xls") #新建excel
    # sheet1_new = book_excel_new.add_sheet(sheetname="1",cell_overwrite_ok=True)
    
    while(1):
         #输入书名
        print("1.请输入借书书名\n2.按q退出借书界面")
        bookname = input()
        if(bookname == 'q'):
            return 
        else:
        #查找
            a = 0
            for i in range(0, book_num):
                if( bookname == sheet1.cell(i, 0).value ):
                    for j in range(4):
                        a = i + 1
                        while(book_num-a):
                            sheet1_copy.write(i,j,sheet1.cell(a,j).value)#清除位置
                            a += 1
                        print("借阅成功")   
                        book_excel_copy.save('图书.xls')
                        return
                    # else:
                    #     a = i
                    #     sheet1_copy.write(i,j,sheet1.cell(a,j).value)#清除位置
            
            #book_excel_copy.save('图书.xls')
             

if __name__ == '__main__':
    book_num = read_book_num()
    print(book_num)
    while(1):
        print("******图书管理系统****")
        print("******1.添加新书******")
        print("******2.查询书籍******")
        print("******3.借书*********")
        print("******4.退出*********")
        op = input("请输入你的操作:")
        if(op == "1"):
            add_book(book_num)
        elif (op == "2"):
            search_book()
        elif (op == "3"):
            borrow_book()
        elif (op == "4"):
            break
        else:
            print("输入无效,请重新输入!")

2.用txt文件方式存储

def add_book():
    file = open("图书管理系统.txt","a+")
    print("请输入要添加的书籍信息:")
    id = input("id:")
    name = input("bookname:")
    author = input("author:")
    #table = [name,id,author]
    file.write(id+" "+name+" "+author+"\r")
    print("书籍添加成功!")
    file.close()

def serch_book():
    file = open("图书管理系统.txt","r")
    name = input("请输入要查询书籍名称:")

    read_data_all = []
    count = len(file.readlines())
    #print(count)

    file.seek(0,0) #需要将文件指针移动到开头

    for i in range(count):
        read_data = file.readline().split()
        read_data_all.append(read_data)
        
    for read_data in read_data_all:
        # print(type(read_data))
        if(name==read_data[0]): 
            print("查询到的数据信息为:",read_data)
            break
    else:
        print("查找失败")
    file.close()
    return read_data

def borrow_book():
    

    file = open("图书管理系统.txt","r+")
    #先查找书籍存不存在,如果存在就借出
    count = len(file.readlines())
    read_data_all= []
    file.seek(0,0) #需要将文件指针移动到开头
    for i in range(count):
        read_data = file.readline().split()
        read_data_all.append(read_data)
    print(read_data_all)
    file.close()

    book = serch_book()
    file = open("图书管理系统.txt","w")
    
    for line in read_data_all:
        if book==line:
            continue
        line_to_str = ' '.join(line) #将列表装换成字符串
        file.write(line_to_str+"\n")

if __name__ == "__main__":
    #open直接打开一个文件,如果文件不存在则创建文件
    
    while(1):
        print("******图书管理系统****")
        print("******1.添加新书******")
        print("******2.查询书籍******")
        print("******3.借书**********")
        print("******4.退出**********")
        op = input("请输入你的操作:")
        if(op == "1"):
            add_book()
        elif(op == "2"):
            serch_book()
        elif(op == "3"):
            borrow_book()
        else:
            break

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • python实现图书管理系统

    本文实例为大家分享了python实现图书管理系统的具体代码,供大家参考,具体内容如下 import mysql.connector import sys, os import time import datetime from tkinter import * from tkinter.messagebox import * class Libop: user = 'root' pwd = '' host = 'localhost' db = 'library' data_file = 'mys

  • Python实现简易的图书管理系统

    本文实例为大家分享了Python实现简易图书管理系统的具体代码,供大家参考,具体内容如下 首先展示一下图书管理系统的首页: 这是图书管理系统的发布图书页面: 最后是图书管理系统的图书详情页已经图书进行删除的管理页. 该图书管理系统为练习阶段所做,能够实现图书详情的查询.图书的添加.图书的删除功能.以下附源码: views.py文件中代码如下: from django.shortcuts import render,redirect,reverse from django.db import co

  • Python实现图书借阅管理系统

    本篇文章将编写一个python简易的图书借阅管理系统,可以实现一些基本的功能. 图书借阅管理系统需求分析: 1. 书籍的属性信息:书名, 作者, 借阅状态(借出数量, 未借的数量)2. 书籍借阅需要的操作: 1). 录入书籍信息:2). 借阅书籍信息:3). 归还书籍:4). 查询书籍信息:5). 退出 主要思路: 用户进入系统后,可以通过键入数字1-5去实现相对应的功能,并且可以重复操作,直到输入数字5之后退出系统. 先创建一个空的列表,作为一个存放书籍信息的容器,执行程序时先进行初始化,自动

  • python图书管理系统

    本文实例为大家分享了python图书管理系统的具体代码,供大家参考,具体内容如下 实现语言:python 图形框架:DTK+2.0 数据库框架:SQLite 3.0 本程序需要以下部件运行: Python2.5.0.GTK+2.16.Pygtk 2.16.PyGobject 2.14.Pycairo 1.4 LibiaryManager.py #!/usr/bin/python # -*- coding: utf-8 -*- import pygtk pygtk.require('2.0') i

  • python代码实现图书管理系统

    本文实例为大家分享了python代码实现图书管理系统的具体代码,供大家参考,具体内容如下 图书管理系统 功能简介 添加图书时,图书ID不能重复,图书名可重复 删除,查询,修改功能,输入图书名之后提供所有的同名的图书,用户可以按照图书序号对具体的一本书进行操作 显示书籍,分行显示,每行一本书的信息 书籍信息以如下格式保存在txt文本文件格式下 源代码 #-*- coding=utf8 -*- # @author:sololi # date: 2020/11/12 # 文件说明 : data imp

  • python实现简单图书管理系统

    用python实现一个简单的图书管理系统 ,供大家参考,具体内容如下 1.工具:PyCharm3.6 社区版 我创建了一个工程叫fairy,把解释器换成Pytnon3.6 创建一个pytnon file:图书管理系统.py 2.实现简单界面如下: """ 图书管理系统 1.查询图书 2.增加图书 3.借阅图书 4.归还图书 5.退出系统 """ 3.代码实现 # 书的属性:书名,作者,状态,位置 # 管理系统: class Book(object

  • wxpython实现图书管理系统

    用wxpython实现的简单图书管理系统,可以实现增加图书,删除图书,修改图书,查看图书.后台数据库为mysql数据库,采用的pymysql连接数据库.系统界面如下: 代码如下: 1.书本类代码 #author = liuwei date = 2017-06-02 from datetime import * #导入日期模块 __metaclass__ = type class Book: '''一个书本信息类,包括书本名字,作者名字和书本简单信息''' def __init__(self, b

  • 基于python实现图书管理系统

    本文实例为大家分享了python实现图书管理系统的具体代码,供大家参考,具体内容如下 添加新书 查询 借阅 二次添加新书(读取已有的.xls并修改) 代码: import xlwt import xlrd def read_old_data(row0_len): try: filename=".\图书.xls" old_data = []#读取表格已有内容 data = xlrd.open_workbook(filename) sheet0 = data.sheet_by_index(

  • python编写图书管理系统

    本文实例为大家分享了python实现图书管理系统的具体代码,供大家参考,具体内容如下 题目:写一个简单的图书借阅系统‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬ 学校二手书是个大市场,A老师决定涉足这个领域,她需要写一个图书管理系统帮她管理书籍的借阅情况,她希望这个程序可以做到:‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬

  • Python简易版图书管理系统

    本文实例为大家分享了python图书管理系统的具体代码,供大家参考,具体内容如下 """ 图书管理系统 """ import random # books={书名:剩余数量, 书名:剩余数量} import time books = {"防脱发指南": 5, "颈椎康复指南": 3, "从删库到跑路": 0} # students_books=[name,{书}] students_bo

  • Python实现图书管理系统设计

    基于python的tkinter,将图书管理系统的界面进行简单的开发,我在这里使用的方法比较简单理解,但是代码过于繁多.添加.删除及修改并未使用数据库,而是使用了csv文件的读取操作,从而替代数据库. 基本效果如下图所示: 该系统将所有代码全都放在一个文件中,源码如下: import os import tkinter import tkinter.messagebox from tkinter import * from tkinter import ttk   class LoginPage

  • 教你用python实现一个无界面的小型图书管理系统

    一.需求了解 功能模块 图书信息 二.环境准备 安装mysql数据库 参考文章: MySQL数据库压缩版本安装与配置 MySQL msi版本下载安装图文教程 创建数据库表 创建数据库 CREATE DATABASE bookmanage; 使用数据库 use bookmanage; 创建表 create table books( id int unsigned primary key auto_increment not null, name varchar(20) default ""

随机推荐