欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)簡易圖書管理系統(tǒng)

 更新時間:2022年03月10日 13:13:52   作者:w2大大  
這篇文章主要為大家詳細介紹了python實現(xiàn)簡易圖書管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了python實現(xiàn)簡易圖書管理系統(tǒng)的具體代碼,供大家參考,具體內容如下

一、設計需求

1.添加書籍
2.查詢數(shù)據
3.借書

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

二、實現(xiàn)代碼

1.用excel存儲

# 一、介紹
# 主要功能實現(xiàn)
# 1、借書
# 2、添加新書
# 3、查找圖書

# 數(shù)據存儲:excel表

import xlwt
import xlrd
import xlutils.copy
import os

#book = {"位置":"","書名":"","價格":"","作者":""}
#存儲方式 ?用excel
title =["位置","書名","價格","作者"]

#查看當前的書本數(shù),也就行號
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是否存在,如果不存在,就創(chuàng)建
? ? 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")?
? ? ? ? #并復制之前的已經存在的數(shù)據
? ? ? ? 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)
? ? ? ? ? ? #存儲到硬盤(將輸入的數(shù)據存儲到excel中)
? ? ? ? ? ? for i in range(4):
? ? ? ? ? ? ? ? #寫入第book_num行數(shù)據
? ? ? ? ? ? ? ? sheet1.write(book_num,i,book[i])
? ? ? ? ? ? book_num = book_num +1 #總書數(shù)量加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)
? ??
? ? #重新創(chuàng)建一個excel,用于保存更新后的數(shù)據
? ? # 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("******圖書管理系統(tǒng)****")
? ? ? ? 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("圖書管理系統(tǒng).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("圖書管理系統(tǒng).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("查詢到的數(shù)據信息為:",read_data)
? ? ? ? ? ? break
? ? else:
? ? ? ? print("查找失敗")
? ? file.close()
? ? return read_data

def borrow_book():
? ??

? ? file = open("圖書管理系統(tǒng).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("圖書管理系統(tǒng).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直接打開一個文件,如果文件不存在則創(chuàng)建文件
? ??
? ? while(1):
? ? ? ? print("******圖書管理系統(tǒng)****")
? ? ? ? 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 Numpy 高效的運算工具詳解

    Python Numpy 高效的運算工具詳解

    這篇文章主要介紹了Python numpy矩陣處理運算工具用法匯總,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2021-10-10
  • Anaconda環(huán)境變量的配置圖文詳解

    Anaconda環(huán)境變量的配置圖文詳解

    Anaconda指的是一個開源的Python發(fā)行版本,其包含了conda、Python等180多個科學包及其依賴項,下面這篇文章主要給大家介紹了關于Anaconda環(huán)境變量配置的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • 五個Jupyter?Notebook實用魔法命令分享

    五個Jupyter?Notebook實用魔法命令分享

    Jupyter?Notebook是一個開源的交互式編程環(huán)境,用于創(chuàng)建和共享包含實時代碼、文本等,本文主要來和大家分享一些有趣的Jupyter?Notebook魔法命令,需要的可以參考一下
    2023-07-07
  • Python Pandas批量讀取csv文件到dataframe的方法

    Python Pandas批量讀取csv文件到dataframe的方法

    這篇文章主要介紹了Python Pandas批量讀取csv文件到dataframe的方法,需要的朋友可以參考下
    2018-10-10
  • python代碼實現(xiàn)ID3決策樹算法

    python代碼實現(xiàn)ID3決策樹算法

    這篇文章主要為大家詳細介紹了python代碼實現(xiàn)ID3決策樹算法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • python實現(xiàn)猜拳游戲項目

    python實現(xiàn)猜拳游戲項目

    這篇文章主要為大家詳細介紹了python實現(xiàn)猜拳游戲項目,以excel形式保存信息,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Python下opencv圖像閾值處理的使用筆記

    Python下opencv圖像閾值處理的使用筆記

    這篇文章主要介紹了Python下opencv圖像閾值處理的使用筆記,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08
  • python爬蟲之selenium模塊

    python爬蟲之selenium模塊

    本文詳細講解了python爬蟲之selenium模塊,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • python進階學習實時目標跟蹤示例詳解

    python進階學習實時目標跟蹤示例詳解

    這篇文章主要為大家介紹了python進階學習實時目標跟蹤示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • python繪制箱線圖boxplot()的教程詳解

    python繪制箱線圖boxplot()的教程詳解

    本文主要介紹了python如何繪制箱線圖boxplot()的方法教程,文中有詳細的代碼示例和圖文講解,需要的朋友可以參考下
    2023-05-05

最新評論