Java小白翻身-Excel教程

嗯,先让我们捋一捋思路吧~

private static boolean saveCustomer(ICustomerService customerService) {
		//1、读取文本,获取客户资料
		List<String> props = customerService.loadCustomerFormTxt("D:/customer.txt");
		//2、解析客户资料到客户对象
		Customer customer = customerService.fillCustomer(props);
		//3、直接将客户对象保存到Excel中(暂时先不做批量入库了)
		boolean isSuccess = customerService.saveToExcel(Application.cstList,"D:/customer.xls");

		Application.cstList.add(customer);

		return isSuccess;
	}

首先,我们捋一捋思路,顺便复习一下之前保存用户的方法。之前的做法是,如果用户选择【客户登记入库】,程序则去读取D盘的customer.txt文件,然后转换里面的信息到cstList里面。

Application.cstList.add(customer);

这个是方便我们看到刚刚保存的数据,现在我们的难点在于,如何实现将客户对象保存到Excel中?

在CustomerServiceImpl中,我们的saveToExcel方法这是一个壳子,实际上并没有实现保存逻辑呢。

    @Override
    public boolean saveToExcel(TuziLinkedList customers, String excelPath) {

        customers.forEachRemaining(new Consumer() {
            @Override
            public void accept(Object o) {
                //把Object类型的o对象,强制转化成Customer类型
                Customer cst = (Customer) o;
                System.out.println(cst.getName() + "已经成功保存到Excel!");
            }
        });

        return true;
    }

这个时候,我们就发现问题了,就是saveToExcel这个方法,接收的参数是customers,是TuziLinkedList类型的。这就表明,需要的是一个容器,这个容器里面可能有多个客户对象啊,所以我们的注释写的就有点问题。具体为啥这样写,好像是我打算做成单个入库的,不做批量入库。

似乎是我忘记改了,咳咳… … 小细节,小细节,不要在意。。。

我们得重新设计一下saveToExcel这个方法,修改其参数为当前的客户对象。

Java小白翻身-Excel教程

Java小白翻身-Excel教程

Java小白翻身-Excel教程

然后修改这里:

Java小白翻身-Excel教程

Java小白翻身-Excel教程

然后就发现,这个方法报错了,因为我们刚刚把容器对象改成了单个客户对象。注意,虽然现在参数的名字还叫做customers,但是注意看它左边的类型,已经是Customer,而不是之前的TuziLinkedList了。为了安全起见,不造成混淆,我们也把customers改成customer。(接口里面也要改)

Java小白翻身-Excel教程

Java小白翻身-Excel教程

再回到实现类,发现这一块报错了。

Java小白翻身-Excel教程

我们在上一节的【接口】章节中,讲解了这个属于 new一个匿名实现类 ,它是java中的一个高级写法。我们现在为了项目进度,只打算做单个保存,不做批量保存,就暂时用不到了。但是,这种写法还是非常不错的,绝对的装逼利器,值得大家好好品鉴和体会(偷偷告诉你,在很多框架里面,到处都是这种写法。如果再弄得逼格高点,就是所谓的Lamda表达式了,这个暂且不谈)。

好不容易写出来,删掉可惜,我们就注释掉吧。

    @Override
    public boolean saveToExcel(Customer customer, String excelPath) {

//        customers.forEachRemaining(new Consumer() {
//            @Override
//            public void accept(Object o) {
//                //把Object类型的o对象,强制转化成Customer类型
//                Customer cst = (Customer) o;
//                System.out.println(cst.getName() + "已经成功保存到Excel!");
//            }
//        });

        return true;
    }

没错,还是要用到Hutool,没想到吧。Hutool封装了POI(一种java跟office打交道的lib库),把Excel的生成变得格外简单了。

Java小白翻身-Excel教程

为了方便大家练习,我会直接放出整个项目的下载地址,也包括了这两个jar包。

@Override
public boolean saveToExcel(Customer customer, String excelPath) {

    //通过工具类创建writer
    ExcelWriter writer = ExcelUtil.getWriter(excelPath);

    //定义标题
    writer.addHeaderAlias("name", "客户姓名");
    writer.addHeaderAlias("sex", "性别");
    writer.addHeaderAlias("birthDate", "生日");
    writer.addHeaderAlias("phoneNumber", "电话号码");

    // 合并单元格后的标题行,使用默认标题样式
    writer.merge(4, "客户信息");

    //将customer放入一个List
    List list = new ArrayList();
    list.add(customer);

    writer.write(list);
    writer.flush();

    return true;
}

注释都写的很清楚了,其中用到了ArrayList,这是jdk给我们提供的一种List数据结构,用法就和我们的TuziLinkedList差不多,现在我们只需要能看懂就行。
简单演示一下目前的操作流程

这个小得不能再小的项目,当然还存在着很多的问题。比如,每次只能保存一个用户,而且还需要把用户信息写在一个txt文档里面,这样也太奇葩了吧!

哈哈,没错,不过软件本来就是需要不断更新与迭代的。诚然,我相信没有一家软件公司会把数据全部存到Excel里面吧,那样根本就没法维护。实际上,后面我们会学习到一个叫做数据库的东西。接下来的几个章节,我们就要回到知识点的讲解中。

最后,说一下,为什么我们要做这样的一个小小项目呢?那是因为,我希望通过这个小案例,让初学Java的人,一开始面对的不是冷冰冰的知识点,背书本,而是能用最快的速度,学会用Java做一个有使用价值的东西出来。

这个项目虽然还非常不合理,但是,它用到了很多知识点。比如接口,IO,生成Excel(虽然Hutool帮了大忙,但是我们还是完成了最基本的功能)。

至于生成Excel的部分,大家无需过多地去介意。因为目前是肯定不合理的,因为用户会很多,不可能每次都去重新生成一个Excel,而应该每次获取到Excel里面所有的用户数据,然后新增一个用户,再重新写一个excel出去。

可即便是这样,效率还是太低。

什么时候用Excel,在企业里面,其实也就是生成个报表啥的,一次性的。比如你有100条数据,就生成包含100条数据的excel文档。没有把excel当成数据库的。

这个项目也仅仅是带着大家看一看,Java能干的事情还是有点多的。哪怕,我们只学了最最简单的面向对象,接口,还有如何定义和调用方法等知识点。

不过话又说回来,学习哪有一蹴而就的呢?我认为一开始能否建立起自信心是最重要的,不管怎么说,目前我们用最简单的Java代码,做了一个能跑的程序的出来,还能读取txt,生成Excel文档,这就很ok了。

至于后面,肯定是要快速地进入到web的学习,因为现在你学java,去找工作,基本都是web。

https://www.bilibili.com/video/BV1j5411N7q3?p=2

上一篇:对于Reactor的理解


下一篇:Elasticsearch语法和MySQL对比使用教程