网易首页 > 网易号 > 正文 申请入驻

一个完整的图书借阅管理系统的Python实现

0
分享至

以下是一个完整的图书借阅管理系统的Python实现,包含核心功能(图书管理、借阅/归还、查询等),无需任何外部库或网址依赖,直接运行即可使用:

完整代码

python

import datetime

class Book:

def __init__(self, book_id, title, author, total_copies=1):

self.book_id = book_id #图书ID

self.title = title #书名

self.author = author #作者

self.total_copies = total_copies #总副本数

self.available_copies = total_copies #可借副本数

self.borrow_records = [] #借阅记录(记录用户ID和借阅日期)

def __str__(self):

return f"ID: {self.book_id} |书名: {self.title} |作者: {self.author} |可借副本: {self.available_copies}/{self.total_copies}"

class User:

def __init__(self, user_id, name):

self.user_id = user_id #用户ID

self.name = name #用户名

self.borrowed_books = {} #借阅的图书{book_id:归还截止日期}

def __str__(self):

return f"用户ID: {self.user_id} |姓名: {self.name} |当前借阅: {len(self.borrowed_books)}本"

class Library:

def __init__(self):

self.books = {} #所有图书{book_id: Book对象}

self.users = {} #所有用户{user_id: User对象}

self.borrow_period = 30 #默认借阅期限(天)

# ==========图书管理==========

def add_book(self, book_id, title, author, copies=1):

if book_id in self.books:

print("❌ 图书ID已存在!")

else:

self.books[book_id] = Book(book_id, title, author, copies)

print(f"✅ 成功添加图书: {title} (共{copies}本)")

def remove_book(self, book_id):

if book_id not in self.books:

print("❌ 图书不存在!")

elif self.books[book_id].borrow_records:

print("❌ 图书有未归还记录,无法删除!")

else:

del self.books[book_id]

print(f"✅ 已删除图书ID: {book_id}")

# ==========用户管理==========

def register_user(self, user_id, name):

if user_id in self.users:

print("❌ 用户ID已存在!")

else:

self.users[user_id] = User(user_id, name)

print(f"✅ 成功注册用户: {name}")

# ==========借阅功能==========

def borrow_book(self, user_id, book_id):

if user_id not in self.users:

print("❌ 用户不存在!")

elif book_id not in self.books:

print("❌ 图书不存在!")

elif self.books[book_id].available_copies <= 0:

print("❌ 图书已全部借出!")

else:

user = self.users[user_id]

book = self.books[book_id]

#记录借阅

due_date = datetime.date.today() + datetime.timedelta(days=self.borrow_period)

user.borrowed_books[book_id] = due_date

book.available_copies -= 1

book.borrow_records.append((user_id, datetime.date.today()))

print(f"✅ 用户{user.name}成功借阅《{book.title}》,请于{due_date}前归还。")

def return_book(self, user_id, book_id):

if user_id not in self.users:

print("❌ 用户不存在!")

elif book_id not in self.books:

print("❌ 图书不存在!")

elif book_id not in self.users[user_id].borrowed_books:

print("❌ 用户未借阅此书!")

else:

user = self.users[user_id]

book = self.books[book_id]

#归还图书

del user.borrowed_books[book_id]

book.available_copies += 1

#检查是否逾期

due_date = user.borrowed_books[book_id]

today = datetime.date.today()

if today > due_date:

days_overdue = (today - due_date).days

print(f"⚠️图书已逾期{days_overdue}天,请尽快缴纳罚款!")

else:

print(f"✅ 用户{user.name}已归还《{book.title}》。")

# ==========查询功能==========

def search_books(self, keyword):

results = []

for book in self.books.values():

if (keyword.lower() in book.title.lower() or

keyword.lower() in book.author.lower() or

keyword.lower() in book.book_id.lower()):

results.append(book)

if results:

print("\n�� 搜索结果:")

for book in results:

print(book)

else:

print("❌ 未找到匹配的图书!")

def list_all_books(self):

if not self.books:

print("�� 图书馆暂无图书!")

else:

print("\n�� 所有图书:")

for book in self.books.values():

print(book)

def list_user_borrowed(self, user_id):

if user_id not in self.users:

print("❌ 用户不存在!")

else:

user = self.users[user_id]

print(f"\n��{user.name}的借阅记录:")

if not user.borrowed_books:

print("无借阅记录")

else:

for book_id, due_date in user.borrowed_books.items():

book = self.books.get(book_id, None)

title = book.title if book else "未知图书"

print(f"-《{title}》(截止日期: {due_date})")

# ==========主菜单==========

def main():

library = Library()

#预置测试数据

library.add_book("B001", "三体", "刘慈欣", 2)

library.add_book("B002", "平凡的世界", "路遥", 1)

library.register_user("U001", "张三")

library.register_user("U002", "李四")

while True:

print("\n===图书借阅管理系统===")

print("1.图书管理")

print("2.用户管理")

print("3.借阅/归还")

print("4.查询")

print("5.退出系统")

choice = input("请选择功能(1-5): ").strip()

#图书管理

if choice == "1":

print("\n---图书管理---")

print("1.添加图书")

print("2.删除图书")

print("3.查看所有图书")

sub_choice = input("请选择操作(1-3): ").strip()

if sub_choice == "1":

book_id = input("输入图书ID: ").strip()

title = input("输入书名: ").strip()

author = input("输入作者: ").strip()

copies = int(input("输入副本数量: ").strip() or 1)

library.add_book(book_id, title, author, copies)

elif sub_choice == "2":

book_id = input("输入要删除的图书ID: ").strip()

library.remove_book(book_id)

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
安在旭和苏志燮吊唁安圣基,宋承宪哭了,车仁表穿高领毛衣很帅

安在旭和苏志燮吊唁安圣基,宋承宪哭了,车仁表穿高领毛衣很帅

娱圈小愚
2026-01-08 10:38:49
3名男子举报上海移动 为创收逼迫员工上门断用户网络 上海移动客服人员:举报内容是不存在的

3名男子举报上海移动 为创收逼迫员工上门断用户网络 上海移动客服人员:举报内容是不存在的

闪电新闻
2026-01-08 15:01:28
马杜罗迎来帮手,六国挺身而出,四国对美国发出通牒,特朗普急了

马杜罗迎来帮手,六国挺身而出,四国对美国发出通牒,特朗普急了

来科点谱
2026-01-06 09:00:36
法国第一美人消失25年,被救时竟已沦为46斤人畜,亲妈在阁楼里藏了整整25年的秘密终于曝光了

法国第一美人消失25年,被救时竟已沦为46斤人畜,亲妈在阁楼里藏了整整25年的秘密终于曝光了

历史回忆室
2026-01-02 19:54:11
都体:曼联为小因扎吉开1500万镑年薪,但他现在两年5000万欧

都体:曼联为小因扎吉开1500万镑年薪,但他现在两年5000万欧

懂球帝
2026-01-08 18:26:20
微信辟谣网传新规则

微信辟谣网传新规则

界面新闻
2026-01-08 14:53:45
美国人预测:未来20年,世界上最强大的"7个国家",看都有谁?

美国人预测:未来20年,世界上最强大的"7个国家",看都有谁?

小熊侃史
2026-01-07 11:18:33
广东传3好3坏消息!阿旺喊话辽宁,少杰伤情更新,王洪泽发文自勉

广东传3好3坏消息!阿旺喊话辽宁,少杰伤情更新,王洪泽发文自勉

后仰大风车
2026-01-08 06:45:07
汶川地震缺重型直升机痛心,直-17仿支奴干失败,中国终走自研路

汶川地震缺重型直升机痛心,直-17仿支奴干失败,中国终走自研路

暮光视界
2026-01-08 09:46:20
白宫:被扣油轮上船员 可能被带到美国接受审判

白宫:被扣油轮上船员 可能被带到美国接受审判

每日经济新闻
2026-01-08 07:40:58
杜月笙的发妻沈月英,和表哥私会,云雨过后,她含泪嘱咐表哥

杜月笙的发妻沈月英,和表哥私会,云雨过后,她含泪嘱咐表哥

百态人间
2026-01-07 16:41:09
新疆生产建设兵团党委常委、副司令员李旭被查

新疆生产建设兵团党委常委、副司令员李旭被查

澎湃新闻
2026-01-08 18:32:26
13年后王石又做了一锅红烧肉,终究比不过胡歌的那锅红烧肉

13年后王石又做了一锅红烧肉,终究比不过胡歌的那锅红烧肉

阿讯说天下
2026-01-06 15:30:46
正大量上市!这种红薯自带毒素,比喝酒还伤肝,家里有的尽快扔掉

正大量上市!这种红薯自带毒素,比喝酒还伤肝,家里有的尽快扔掉

DrX说
2026-01-08 14:57:29
“AI火了,我们却快完了!”顶级开源框架Tailwind之父含泪裁掉75%兄弟:半年后,这个项目可能就没了

“AI火了,我们却快完了!”顶级开源框架Tailwind之父含泪裁掉75%兄弟:半年后,这个项目可能就没了

InfoQ
2026-01-08 13:32:50
全球哗然!中国“人造太阳”捅破西方理论天花板,这招“笨功夫”让对手慌了

全球哗然!中国“人造太阳”捅破西方理论天花板,这招“笨功夫”让对手慌了

Hi秒懂科普
2026-01-06 19:19:08
白鹿给闺蜜呵呵买车,网友:世界欠我一个白鹿

白鹿给闺蜜呵呵买车,网友:世界欠我一个白鹿

萱小蕾o
2026-01-07 16:55:32
中老年人要远离洋葱?医生提醒:不想进医院,这几物别轻易下嘴

中老年人要远离洋葱?医生提醒:不想进医院,这几物别轻易下嘴

健康之光
2025-12-31 08:55:06
中国驻日大使罕见缺席日方新年问候交流会!日本政坛大佬施压高市

中国驻日大使罕见缺席日方新年问候交流会!日本政坛大佬施压高市

时时有聊
2026-01-08 07:45:16
“买不起羽绒服,还敢生5个孩子?”老师一句话,让家长无地自容

“买不起羽绒服,还敢生5个孩子?”老师一句话,让家长无地自容

妍妍教育日记
2026-01-06 10:18:39
2026-01-08 22:40:49
建邺区生态科技岛人工智能商会
建邺区生态科技岛人工智能商会
南京市建邺区生态科技岛人工智能行业商会
243文章数 0关注度
往期回顾 全部

科技要闻

智谱拿下“全球大模型第一股”,凭什么

头条要闻

10岁抗癌"王子"病情恶化 家人"放弃治疗"孩子憧憬出院

头条要闻

10岁抗癌"王子"病情恶化 家人"放弃治疗"孩子憧憬出院

体育要闻

世乒赛银牌得主,说自己梦里都是孙颖莎

娱乐要闻

抗战剧《马背摇篮》首播,获观众好评

财经要闻

微软CTO韦青:未来人类会花钱"戒手机"

汽车要闻

从量变到"智"变 吉利在CES打出了五张牌

态度原创

时尚
旅游
家居
健康
本地

190万赞的爆款女孩,等待代表作

旅游要闻

特写:在台湾基隆“穿越”刘铭传隧道

家居要闻

理性主义 冷调自由居所

这些新疗法,让化疗不再那么痛苦

本地新闻

1986-2026,一通电话的时空旅程

无障碍浏览 进入关怀版