Java-简陋的图书管理

本文代码为原创一个简陋的管理系统,只做功能的测试。并没有去完善所有应有的功能,只做了输入输出查找。仅供参考!

菜单部分:

 1 import java.util.Scanner;
 2 public class Menu {
 3     int Min = 1;
 4     int Max = 3;
 5     public void getMenu(){
 6         System.out.println("1、显示/2、输入/3、查找");
 7     }
 8     public void getFindMenu(){
 9         System.out.println("1、编号/2、书名/3、作者");
10     }
11     public int setMenu(){
12         System.out.println("输入序号:");
13         Scanner reader = new Scanner(System.in);
14         int num = reader.nextInt();
15         if(num >= Min || num <= Max)
16             return num;
17         else
18             return -1;
19     }
20 }

重点的管理部分:

  1 import java.io.File;
  2 import java.io.FileNotFoundException;
  3 import java.io.FileOutputStream;
  4 import java.util.Scanner;
  5 import java.io.IOException;
  6
  7 public class Book {
  8     public void find(){
  9         Menu menu = new Menu();
 10         menu.getFindMenu();
 11         Scanner reader = new Scanner(System.in);
 12         int num = menu.setMenu();
 13         switch(num){
 14         case 1:
 15             System.out.println("请输入编号");
 16             Find(reader.next(), 0);
 17             break;
 18         case 2:
 19             System.out.println("请输入书名");
 20             Find(reader.next(), 1);
 21             break;
 22         case 3:
 23             System.out.println("请输入作者");
 24             Find(reader.next(), 2);
 25             break;
 26         }
 27     }
 28     public void Find(String s,int n){
 29         try {
 30             Scanner in = new Scanner(new File("res/Book.txt"));
 31             while (in.hasNextLine()) {
 32                 String str = in.nextLine();
 33                 String[] book = str.trim().split("#");
 34                 if(book[n].compareTo(s) == 0)
 35                     System.out.println(book[0] +"  "+ book[1] +"  "+ book[2]);
 36             }
 37         } catch (FileNotFoundException e) {
 38             e.printStackTrace();
 39         }
 40     }
 41     public String findNum(String s,int n){
 42         try {
 43             Scanner in = new Scanner(new File("res/Book.txt"));
 44             while (in.hasNextLine()) {
 45                 String str = in.nextLine();
 46                 String[] book = str.trim().split("#");
 47                 if(book[n].compareTo(s) == 0)
 48                     return book[n];
 49             }
 50         } catch (FileNotFoundException e) {
 51             e.printStackTrace();
 52         }
 53         return "没有找到";
 54     }
 55     public String message(){
 56         Scanner reader = new Scanner(System.in);
 57         String str = "";
 58         String s = "";
 59         System.out.println("请输入编号");
 60         str = reader.next();
 61         if(findNum(str,0).compareTo("没有找到") != 0){
 62             System.out.println("此编号存在输入错误");
 63             return "@@!!";
 64         }
 65         s += str + "#";
 66         System.out.println("请输入书名");
 67         str = reader.next();
 68         s += str + "#";
 69         System.out.println("请输入作者");
 70         str = reader.next();
 71         s += str + "#\n";
 72         return s;
 73     }
 74     public void setBook() {
 75         FileOutputStream fop = null;
 76         File file;
 77         String content = message();
 78         if(content.compareTo("@@!!") == 0)
 79             return ;
 80         try {
 81             file = new File("res/Book.txt");
 82             fop = new FileOutputStream(file,true);
 83             byte[] contentInBytes = content.getBytes();
 84             fop.write(contentInBytes);
 85             fop.flush();
 86             fop.close();
 87             System.out.println("Done");
 88         } catch (IOException e) {
 89             e.printStackTrace();
 90         } finally {
 91             try {
 92                 if (fop != null) {
 93                     fop.close();
 94                 }
 95             } catch (IOException e) {
 96                 e.printStackTrace();
 97             }
 98         }
 99     }
100
101     public void getBook() {
102         try {
103             Scanner in = new Scanner(new File("res/Book.txt"));
104             while (in.hasNextLine()) {
105                 String str = in.nextLine();
106                 splitt(str);
107             }
108         } catch (FileNotFoundException e) {
109             e.printStackTrace();
110         }
111     }
112
113     public static String[] splitt(String str) {
114         String[] book = str.trim().split("#");
115         for (int i = 0; i < book.length; i++) {
116             System.out.println(book[i]);
117         }
118         System.out.println("\n*********************");
119         return book;
120     }
121 }

主函数部分:

 1 public class ManageBook {
 2
 3     public static void main(String[] agse){
 4         Menu menu = new Menu();
 5         Book book = new Book();
 6         while(true){
 7             menu.getMenu();
 8             int num = menu.setMenu();
 9             switch(num){
10                 case 1:
11                     book.getBook();
12                     break;
13                 case 2:
14                     book.setBook();
15                     break;
16                 case 3:
17                     book.find();
18                     break;
19                 case -1:
20                     System.out.println("输入有误");
21                     break;
22                 }
23         }
24     }
25
26 }
时间: 2024-10-06 06:16:09

Java-简陋的图书管理的相关文章

java图书管理的一个小模块(增删改查,不使用数据库)

图书管理模块:某图书管需要对图书进行信息化管理,要求管理员能够进行新增图书,能按照书名进行模糊查看图书能进行价格统计 系统实现如下:1.新增2.查询3.统计价格 1请输入新书:图书号,书名,作者,价格 新增成功,选择其他操作1.新增2.查询3.统计价格 2请输入书名:水1002,水浒传,施耐庵,1081003,喝水好处多,张三,199 选择其他操作1.新增2.查询3.统计价格 3总计:图书10本,价格1020元 //////////////////////////////////////////

【形式化方法:VDM++系列】3.基于VDM++的图书管理系统需求定义

接前文:http://www.cnblogs.com/Kassadin/p/4091040.html 1.Before We Start: 在开始图书管理系统需求定义之前,需要先进行一些说明. 1.1 输入,输出定义 输入:用户需求文字说明 输出:基于VDM++的需求规格说明文档 任何问题只有明确它的输入和输出,才会有一个明确的预期,才有可能获得预期的结果.在这里明确问题的输入输出更加重要.特别需要指出的是,VDM++作为一种形式化方法语言,它主要用于需求分析,而不是代码实现.虽然它的产出是一段

图书管理系统需求说明书

      图书管理系统需求说明书               1引言.............................................................................................................................. 2 1.1编写目的...............................................................................

网上图书商城项目学习笔记-031图书管理模块介绍及添加图书

一.流程分析 1.图书管理模块介绍 2. 3. 4.添加图书第一步 5.添加图书第二步 二.代码 1.view层 (1)body.jsp 1 <body> 2 <h1 align="center">图书管理</h1> 3 <p align="center"> 4 <a href="<c:url value='/admin/AdminBookServlet?method=addPre'/>&q

图书管理模块功能设计

图书管理功能模块的具体功能如下:1 查看图书信息列表:用于显示图书的基本信息.2 图书详细信息:用于显示指定图书的详细信息.3 添加图书信息:用于添加图书信息.4 修改图书信息:用于修改图书信息.5 删除图书信息:用于删除图书信息.6 查询图书信息:用于根据不同条件查询图书信息. 图书档案管理功能模块文件架构如图1所示. 图书档案管理功能模块文件架构如图1所示. 在图书档案管理模块中涉及的数据表是图书信息表(tb_bookinfo).书架设置表(tb_bookcase).图书类型表(tb_boo

图书管理(Loj0034)+浅谈哈希表

图书管理 题目描述 图书管理是一件十分繁杂的工作,在一个图书馆中每天都会有许多新书加入.为了更方便的管理图书(以便于帮助想要借书的客人快速查找他们是否有他们所需要的书),我们需要设计一个图书查找系统. 该系统需要支持 2 种操作: add(s) 表示新加入一本书名为 s 的图书. find(s) 表示查询是否存在一本书名为 s 的图书. 输入格式 第一行包括一个正整数 n,表示操作数. 以下 n 行,每行给出 2 种操作中的某一个指令条,指令格式为: add s find s 在书名 s 与指令

一本通 字符串 图书管理

题目描述 图书管理是一件十分繁杂的工作,在一个图书馆中每天都会有许多新书加入.为了更方便的管理图书(以便于帮助想要借书的客人快速查找他们是否有他们所需要的书),我们需要设计一个图书查找系统. 该系统需要支持 2 种操作: add(s) 表示新加入一本书名为 s 的图书. find(s) 表示查询是否存在一本书名为 s 的图书. 输入格式 第一行包括一个正整数 ,表示操作数. 以下 行,每行给出 2 种操作中的某一个指令条,指令格式为: add s find s 在书名 s 与指令(add,fin

交通银行 Java Socket 服务启动 管理 WINDOWS 版

按照交通银行提供的无界面启动方法试验了很多次,都没有成功,所以自己动手用C# 知识写了一个. 小工具可以判断 交通银行 JAVA SOCKET 服务是否启动,并可以启动/关闭服务 主要代码如下: 判断服务是否启动 引用 :using System.Management; SelectQuery selectQuery = new SelectQuery(“select * from Win32_Process where Name = ‘java.exe’”); object cmdLine =

图书管理小系统

昨天一朋友要我帮她写个"图书管理小系统",一时嘴贱就答应了. 要求如下: 看着还可以,昨晚把基本框架写了下,今天写了一下午,接近600行,总算写完了.由于她明天就要交,我就赶了点,很多地方还没写好. 但总体来说也让我对文件输出输入有了更进一步的了解了,不过没有用结构体指针,用了的话应该可以 节约很多内存.看以后有没有时间 去完善它吧. 发几个界面看看: 先把代码贴下: 1 #include <stdio.h> 2 #include <stdlib.h> 3 #i

Java中的会话管理——HttpServlet,Cookies,URL Rewriting(译)

参考谷歌翻译,关键字直接使用英文,原文地址:http://www.journaldev.com/1907/java-session-management-servlet-httpsession-url-rewriting Java Web应用程序中的会话管理(Session Management)是一个非常有趣的话题.Java Servlet中的会话通过不同的方式进行管理,例如Cookie,HttpSession API,URL重写等. 这是Java Web应用程序系列教程中的第三篇文章,您可能