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

一个完整的图书借阅管理系统的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.

相关推荐
热点推荐
真香预警 低价MacBook性价比无敌!降维打击Windows、等等党最终归宿

真香预警 低价MacBook性价比无敌!降维打击Windows、等等党最终归宿

快科技
2026-03-02 10:50:12
1胜9负,夺冠热门慢慢倒下!作为联盟第一人,或许你被高估了

1胜9负,夺冠热门慢慢倒下!作为联盟第一人,或许你被高估了

老梁体育漫谈
2026-03-02 23:30:56
老两口结婚后将儿女撮合在一起,亲母女嫁给了亲父子,网友热议:“将来孩子出生该怎么喊呢”

老两口结婚后将儿女撮合在一起,亲母女嫁给了亲父子,网友热议:“将来孩子出生该怎么喊呢”

观威海
2026-03-02 09:20:14
印度首富的小儿子:减200多斤又变胖,妻子是高种姓出身的白富美

印度首富的小儿子:减200多斤又变胖,妻子是高种姓出身的白富美

小书生吃瓜
2026-01-20 17:26:45
曝伊朗考虑退出世界杯 小组赛3场均在美国踢 4队按规有望递补参赛

曝伊朗考虑退出世界杯 小组赛3场均在美国踢 4队按规有望递补参赛

我爱英超
2026-03-02 22:59:13
中国男篮获胜仅12小时,又迎一坏消息,出局队伍诞生,新赛程如下

中国男篮获胜仅12小时,又迎一坏消息,出局队伍诞生,新赛程如下

现代小青青慕慕
2026-03-02 14:53:32
1991 年,邓小平特派代表赴美团聚张学良,邀他重返故土,张学良回应:“回大陆可以,但我有三个要求”

1991 年,邓小平特派代表赴美团聚张学良,邀他重返故土,张学良回应:“回大陆可以,但我有三个要求”

文史明鉴
2025-12-21 17:07:19
汪小菲和张兰矛盾升级!张兰哭完不敢对镜头,大S当年真没说错他

汪小菲和张兰矛盾升级!张兰哭完不敢对镜头,大S当年真没说错他

夏末moent
2026-03-02 08:43:40
伊朗反对派人士,建议未来在哈梅内伊殒命处修建以色列大使馆

伊朗反对派人士,建议未来在哈梅内伊殒命处修建以色列大使馆

老马拉车莫少装
2026-03-02 23:16:59
ATP修改争议性规则,辛纳和阿卡都松了一口气

ATP修改争议性规则,辛纳和阿卡都松了一口气

网球之家
2026-03-01 23:28:34
美伊冲突最极端的结果要来了…

美伊冲突最极端的结果要来了…

风风顺
2026-03-02 08:11:44
杀了哈梅内伊后,特朗普访华的气氛变了

杀了哈梅内伊后,特朗普访华的气氛变了

爱下厨的阿酾
2026-03-02 17:06:15
春节刚过完,茅台价格又跌下来了

春节刚过完,茅台价格又跌下来了

深水财经社
2026-03-02 20:35:04
春晚机器人“演员”官宣融资,资金向头部企业集中

春晚机器人“演员”官宣融资,资金向头部企业集中

第一财经资讯
2026-03-02 13:52:12
89岁朱逢博:丈夫病逝18年,她跟着儿子养老

89岁朱逢博:丈夫病逝18年,她跟着儿子养老

细品名人
2026-03-01 07:42:37
南宁市纪委监委最新通报

南宁市纪委监委最新通报

南国今报
2026-03-02 22:11:33
油价大涨运营受限,航空股集体下跌

油价大涨运营受限,航空股集体下跌

第一财经资讯
2026-03-02 13:57:22
美以军事行动引发伊朗“最猛烈”回击 中东危局40小时一文速览

美以军事行动引发伊朗“最猛烈”回击 中东危局40小时一文速览

极目新闻
2026-03-02 06:57:53
三百名内科专家已证实:花生和糖尿病的关系,最好花1分钟看看

三百名内科专家已证实:花生和糖尿病的关系,最好花1分钟看看

健康科普365
2026-03-02 23:05:03
没想到竟然这么多工作需要保密的!网友:不让看非看被一枪毙了

没想到竟然这么多工作需要保密的!网友:不让看非看被一枪毙了

另子维爱读史
2025-12-08 20:58:22
2026-03-03 01:12:49
建邺区生态科技岛人工智能商会
建邺区生态科技岛人工智能商会
南京市建邺区生态科技岛人工智能行业商会
246文章数 0关注度
往期回顾 全部

科技要闻

苹果中国官网上线iPhone 17e,4499元起

头条要闻

媒体:拉里贾尼走向前台 四大关键变量将决定伊朗命运

头条要闻

媒体:拉里贾尼走向前台 四大关键变量将决定伊朗命运

体育要闻

“想要我签名吗” 梅西逆转后嘲讽对手主帅

娱乐要闻

李亚鹏与哥哥和解 只有一条真心话短信

财经要闻

油价飙升 美伊冲突将如何搅动全球经济

汽车要闻

国民SUV再添一员 瑞虎7L静态体验

态度原创

游戏
本地
健康
亲子
房产

《宝可梦》新作M站90分!近年最新鲜的宝可梦体验

本地新闻

津南好·四时总相宜

转头就晕的耳石症,能开车上班吗?

亲子要闻

45岁这年,我这个二胎妈妈决定做一件“疯狂”的事

房产要闻

方案突然曝光!海口北师大附校,又有书包大盘杀出!

无障碍浏览 进入关怀版