文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python如何实现简易图书管理系统

2023-06-29 11:00

关注

这篇“python如何实现简易图书管理系统”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python如何实现简易图书管理系统”文章吧。

一、设计需求

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

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

二、实现代码

1.用excel存储

# 一、介绍# 主要功能实现# 1、借书# 2、添加新书# 3、查找图书# 数据存储:excel表import xlwtimport xlrdimport xlutils.copyimport os#book = {"位置":"","书名":"","价格":"","作者":""}#存储方式  用exceltitle =["位置","书名","价格","作者"]#查看当前的书本数,也就行号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_numdef 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_datadef 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

以上就是关于“python如何实现简易图书管理系统”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯