You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Go to file
孙艺哲 877190c78c
C101112
2 years ago
.vscode kdsfjdfj 2 years ago
.gitignore ADD file via upload 2 years ago
LICENSE Initial commit 2 years ago
README.md C101112 2 years ago
text.drawio 流程图 2 years ago
图书管理.c C10-12 2 years ago
图书管理系统.c 完善系统管理 2 years ago

README.md

图书管理系统

2023年4月 成员1王昊 成员2孙艺哲 成员3张江楠 成员4郭佳慧

项目简介

本系统是程序设计与问题求解课程设计项目,实现了库存零件 CSV 格式数据文件的读取和保存以及数据的增删改查CRUD、排序和图表显示等功能。项目采用 C 语言编程实现,在 VS Code 集成开发环境IDE中用 GCC 进行编译。系统采用模块化设计,程序结构清晰,采用菜单驱动的命令行界面,操作便捷,能够用 CSV 格式读取和保存数据,通用性强,能够用图表展示数据,直观清楚。 下载地址:https://bdgit.educoder.net/mac76tib2/test.git 项目开发过程中采用 Kanban看板进行任务管理和分工协作并使用 Git 对程序代码和文档进行版本管理。任务分工情况如下: | 任务 | 设计 | 开发 | 测试 | 文档 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 每个成员工作量(百分比): | 王昊 | 张江楠 | 郭佳慧 | 孙艺哲 | | 25 | 25 | 25 | 25 |

关于图书管理系统

建立一个图书馆管理系统,可以处理以下对象: 1图书馆基本信息 2图书馆的书籍 3图书馆管理员 4读者信息

需求分析

1查询图书馆的总信息 2查询图书馆藏书信息 3存入新书 4旧书处理 5根据书名检索书刊信息 6查询读者的借阅信息 7查询读者信息 8读者借书 9读者还书 10文件保存 11从文件读取

C1函数模块

1.函数原形int main(); 2.功能调用ShowMainMenu()函数,显示主界面




C2查询图书馆信息模块

函数原形void ShowLibInfo(const Book* book, const Reader* reader); 功能:接受两个形参,分别是图书的链表地址,读者的链表地址,并遍历两个链表,显示出图书的数量和读者的数量




C3查找图书馆藏书信息模块

  1. 函数原形: void ShowLibBook(Book* book);
  2. 功能: 接受一个形参:图书的链表地址,遍历该链表,显示出所有图书的信息



C4存入新书信息模块

  1. 函数原形: Book* AddBook(Book* book);
  2. 功能: 接受一个形参:图书的链表地址,利用尾插对链表进行修改,添加图书



C5:旧书处理信息模块

1函数原形: Book* DealoldBook(Book* book); 2) 功能: 接受一个形参:图书链表的地址,遍历该链表,用书的编号进行匹配,找到该图书后删除该图书,否则返回




C6:查找图书信息模块

1函数原形: void foundBook(Book* book); 2) 功能:接受一个形参:图书链表的地址,遍历该链表,用书的编号进行匹配,找到该图书后显示该图书,否则返回




C7:查询读者借阅信息模块

1函数原形: void foundReader_Info(Reader* reader); 2) 功能: 接受一个形参:读者链表的地址,遍历该链表,用读者的编号进行匹配,找到该读者显示该读者的信息,否则返回




C8:查询读者借书模块

1函数原形: void foundReaderInfo(Reader* reader); 2功能: 接受一个形参:读者链表的地址,遍历该链表,用读者的编号进行匹配,找到该读者显示该读者的借阅信息,否则返回




C9:读者借书模块

1)函数原形: Reader* LendBook(Reader* reader, Book* book); 2)功能:接受两个形参:读者链表地址和图书链表地址,用读者的编号进行匹配,找到该读者后,用图书的编号进行匹配,进行借书,否则返回




C10:读者还书模块

函数原形void returnBook(Reader* reader, Book* book); 功能:接受两个形参:读者链表地址和图书链表地址,用读者的编号进行匹配,找到该读者后,用图书的编号进行匹配,进行还书,否则返回

void returnBook(Reader* reader1, Book* book1)
{
	Reader* reader = reader1;
	Book* book = book1;
	printf("请输入读者的id:");
	int id;
	scanf("%d", &id);
	getchar();
 
	if (reader != NULL)
	{
		while (reader != NULL)
		{
			if (id == reader->iNum)
			{
				printf("请输入要还的书的编号:");
				int id_book;
				scanf("%d", &id_book);
				getchar();
				for (int i = 0; i < reader->iMax; i++)
				{
					if (reader->aiBookId[i] == id_book)
					{
						reader->aiBookId[i] = 0;
						while (book)
						{
							if (id_book == book->iNum)
							{
								book->iAmount++;
								printf("还书成功!\n");
								printf("按任意键返回\n");
								getchar();
								return reader1;
							}
							book = book->next;
						}
					}
				}
				printf("没有找到该图书检查图书的Id\n");
 
				printf("按任意键返回\n");
				getchar();
				return reader1;
			}
			reader = reader->next;
		}
		printf("没有找到该读者检查读者id是否输入有误\n");
		printf("按任意键返回\n");
		getchar();
		return reader1;
	}
}

C11:保存信息模块

1函数原形: void save(Book* book); 2) 功能接受一个形参book的链表地址新建一个文件将链表中的信息保存到硬盘中

void save(Book* book1)
{
	FILE* fp;
	Book* pCur = book1;
	int iCount = 0;
 
	if (pCur == NULL)
	{
		printf("\n没有学生记录!\n");
		return;
	}
 
	if ((fp = fopen("book.txt", "wb")) == NULL)
	{
		printf("创建文件失败!\n");
		getchar();
		exit(1);
	}
	while (pCur)
	{
		fwrite(pCur, sizeof(Book), 1, fp);
		pCur = pCur->next;
		iCount++;
	}
	printf("\n");
 
	printf("保存文件的数据数目为:%d\n", iCount);
	fclose(fp);
}

C12:读取信息模块

1函数原形: Book* read1();
2) 功能打开一个文件将文件中的信息读取到内存中并返回一个Book类型的指针

Book* read1()
{
	FILE* fp;
	Book* pHead = NULL, * pTemp = NULL, * pCur = NULL;
 
	if ((fp = fopen("book.txt", "r")) == NULL)
	{
		printf("\n文件打开失败!请检查文件名!\n");
		exit(0);
	}
	pTemp = (Book*)malloc(sizeof(Book));
	while (fread(pTemp, sizeof(Book), 1, fp))
	{
		if (!pHead)
		{
			pHead = pCur = pTemp;
		}
		else
		{
			pCur->next = pTemp;
			pCur = pTemp;
		}
		pTemp = (Book*)malloc(sizeof(Book));
	}
	fclose(fp);
	return pHead;
}