java导入和导出excel直接就能用

这篇博客总结了如何在Java中进行Excel的导入和导出操作。首先介绍了需要引入的相关jar包,接着提到了使用的工具类,阐述了如何实现Excel数据的导出。对于导入部分,博主解释了通过解析Excel内容来将数据存入数据库的过程。
摘要由CSDN通过智能技术生成

最近工作中有导入导出的工作,在网上找了半天也没找个所以然,所以在此总结下。新手上路,请多指教!

首先引入几个jar包

<dependency>
            <groupId>com.opencsv</groupId>
            <artifactId>opencsv</artifactId>
            <version>3.3</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.15</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.15</version>
        </dependency>
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.2</version>
        </dependency>
        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>2.6</version>
        </dependency>
        <!--也要引入lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.8</version>
        </dependency>

然后引用两个工具类

package com.hyit.appdev.util;

import lombok.extern.slf4j.Slf4j;
import org.apache.commons.io.IOUtils;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import javax.servlet.http.HttpServletResponse;
import java.io.*;
import java.net.URLEncoder;
import java.nio.charset.Charset;

/**
 * 网页导出工具类
 */
@Slf4j
public class ExportUtil {

    private final static int buffer_size = 1024 * 10;

    /**
     * 导出excel
     *
     * @param response
     * @param workbook
     * @param fileName
     * @throws IOException
     */
    public static void export(HttpServletResponse response, XSSFWorkbook workbook, String fileName) throws IOException {
        response.setContentType("application/vnd.ms-excel;charset=utf-8");
        response.setHeader("Content-Disposition",
                "attachment;fileName=" + URLEncoder.encode(fileName, Charset.forName("UTF-8").toString()));
        OutputStream outputStream = null;
        try {
            outputStream = response.getOutputStream();
            outputStream.flush();
            workbook.write(outputStream);
        } catch (IOException e) {
            log.error("output is closed");
        } finally {
            IOUtils.closeQuietly(outputStream);
        }
    }

    /**
     * 导出csv
     *
     * @param response
     * @param data
     * @param fileName
     * @throws UnsupportedEncodingException
     */
    public static void export(HttpServletResponse response, StringBuilder data, String fileName) throws UnsupportedEncodingException {
        response.setContentType("application/vnd.ms-excel;charset=utf-8");
        response.setHeader("Content-Disposition",
                "attachment;fileName=" + URLEncoder.encode(fileName, Charset.forName("UTF-8").toString()));
        char[] buffer = new char[buffer_size];
        InputStream is = null;
        InputStreamReader isr = null;
        OutputStream os = null;
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值