抖音资讯

douyinzx

java解析excel导入数据(java数据按模板导出excel)

iseeyu2年前 (2024-05-08)抖音资讯109

一、需求说明

通过接口上传一个姓名号码表,返回一个"姓名,号码"格式的的一个String数组。

 

二、功能实现

1、pom.xml中引入依赖

<dependency>

 <groupId>org.apache.poi</groupId>

 <artifactId>poi</artifactId>

 <version>4.1.2</version>

</dependency>

<dependency>

 <groupId>org.apache.poi</groupId>

 <artifactId>poi-ooxml</artifactId>

 <version>4.1.2</version>

</dependency>

使用poi去解析excel,poi对应的是excel2003,poi-ooxml对应的是excel2007。

 

2、实现上传接口

@RestController

@RequestMapping("/testFile")

public class FIleUpDownLoadController {

  @Autowired

  private FileParserService fileParserService;

  @ApiOperation(value = "上传excel文件")

  @RequestMapping(value = "/target", method = RequestMethod.POST)

  @ResponseBody

  public ResponseEntity importTarget(@RequestParam("file") MultipartFile file, HttpServletResponse response) {

    ResponseEntity res = new ResponseEntity();

    try {

      String fileName = file.getOriginalFilename();

      if (!fileName.endsWith(".xls")) {

        res.setCode(ReturnCodeMsgEnum.IMPORT_EXCEL_FORMAT.getCode());

        res.setMsg(ReturnCodeMsgEnum.IMPORT_EXCEL_FORMAT.getMsg());

        return res;

      }

      //接收文件流和解析excel

      List<String> rows = fileParserService.splitRows(file);

      //无错误,不需要返回下载文件,且执行保存数据库

      res.setCode(ReturnCodeMsgEnum.IMPORT_EXCEL_SUCCESS.getCode());

      res.setMsg(ReturnCodeMsgEnum.IMPORT_EXCEL_SUCCESS.getMsg());

      res.setData(rows);

      return res;

    }catch(Exception e){

      logger.error("importTarget error", e);

      res.setCode(ReturnCodeMsgEnum.IMPORT_EXCEL_ERROR.getCode());

      res.setMsg(ReturnCodeMsgEnum.IMPORT_EXCEL_ERROR.getMsg());

      res.setData(e.getMessage());

      return res;

    }

  }

}

主要就是使用MultipartFile类型的参数进行文件流的上传。通过file.getOriginalFilename()去获取上传文件的名称。

 

3、流的处理和excel表格的解析

@Service("fileParserService")

public class FileParserServiceImpl implements FileParserService {

  public static final String EXCEL_2003 = ".xls";

public static final String EXCEL_2007 = ".xlsx";

public static final String COMMA = ",";

private static final Logger log = LoggerFactory.getLogger(FileParserServiceImpl.class);

@Override

public List<String> splitRows(MultipartFile file) throws FileParserServiceException {

  // skip validation

  List<String> rows = null;

  try (InputStream inputStream = file.getInputStream()) {

    String fileName = file.getOriginalFilename();

    Workbook workbook = null;

    if (fileName.endsWith(EXCEL_2003)) {

      workbook = new HSSFWorkbook(inputStream);

    } else if (fileName.endsWith(EXCEL_2007)) {

      workbook = new XSSFWorkbook(inputStream);

    }

    if (workbook != null) {

      rows = new ArrayList<>();

      //sheet页数

      int numOfSheet = workbook.getNumberOfSheets();

      if(numOfSheet>1){

        throw new FileParserServiceException("不支持多个sheet上传");

      }

      for (int i = 0; i < numOfSheet; i++) {

        Sheet sheet = workbook.getSheetAt(i);

        if (sheet == null) continue;

        //行数

        int lastRowNum = sheet.getLastRowNum();

        if (lastRowNum == 0) continue;

        Row row;

        //列数

        short lastCellNum = sheet.getRow(1).getLastCellNum();

        for (int j = 1; j <= lastRowNum; j++) {

          StringBuilder sb = new StringBuilder();

          row = sheet.getRow(j);

          if (row == null) {

            throw new FileParserServiceException("当前文件存在空行,请重新上传");

          }

          String mNum = "";

          Cell cellA = row.getCell(0);

          if (cellA != null) {

            cellA.setCellType(CellType.STRING);

            mNum = cellA.getStringCellValue().trim();

          }

          sb.append(mNum).append(COMMA);

          //遍历每一行

          for (int k = 1; k < lastCellNum; k++) {

            String res = "";

            Cell cell = row.getCell(k);

            if (cell == null) {

              continue;

            }else if(cell.getCellTypeEnum() == CellType.BLANK){

              continue;

            }

            if (cell.getCellTypeEnum() == CellType.NUMERIC) {

              if (DateUtil.isCellDateFormatted(cell)) {

                Date theDate = cell.getDateCellValue();

                short s = cell.getCellStyle().getDataFormat();

                if (s == 0x16) {

                  res = new SimpleDateFormat(Constants.DATE_FORMAT_B).format(theDate);

                } else if (s == 0x12 || s == 0x14) {

                  res = new SimpleDateFormat(Constants.DATE_FORMAT_C).format(theDate);

                } else if (s == 0x13 || s == 0x15 || s == 181 || s == 0x2e || s == 176 || s == 177) {

                  res = new SimpleDateFormat(Constants.DATE_FORMAT_D).format(theDate);

                } else if (s == 0x2d) {

                  res = new SimpleDateFormat(Constants.DATE_FORMAT_E).format(theDate);

                } else {

                  res = new SimpleDateFormat(Constants.DATE_FORMAT_A).format(theDate);

                }

              } else {

                double value = cell.getNumericCellValue();

                if (isInt(value)) {

                  res = String.valueOf(new Double(value).intValue());

                } else if (isLong(value)) {

                  res = new BigDecimal(value).toString();

                } else {

                  res = String.valueOf(value);

                }

              }

              sb.append(res).append(COMMA);

              continue;

            }

            cell.setCellType(CellType.STRING);

            res = cell.getStringCellValue();

            if(res.contains(":")||res.contains(",")){

              throw new FileParserServiceException("当前文件存非法字符(,或:),请重新上传");

            }

            if (res.isEmpty())

              continue;

            sb.append(res).append(COMMA);

          }

          rows.add(sb.substring(0, sb.length() - 1));

        }

      }

    }

  } catch (IOException e) {

    log.error("splitRows error", e);

  }

  return rows;

}

}

(1)流的获取

file.getInputStream()

 

(2)流转换成Workbook

Workbook workbook = null;

if (fileName.endsWith(EXCEL_2003)) {

workbook = new HSSFWorkbook(inputStream);

} else if (fileName.endsWith(EXCEL_2007)) {

workbook = new XSSFWorkbook(inputStream);

}

 

(3)解析excel

主要就是获取sheet页,获取行数,获取列数,遍历获取每个单元格。其中还涉及到单元格数字和字符串的解析问题。

 

三、测试验证

使用postman工具调用接口验证,符合需求。

localhost:8089/testFile/target

 

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/42551.html

相关文章

快手广告平台有哪些优势?快手短视频广告如何投放?

快手广告平台有哪些优势?快手短视频广告如何投放?

随着短视频遍布全球,作为知名短视频平台,快手在国内短视频领域占据一席之地。截至2020年,快手注册用户数已达8亿多,日活跃用户数达3亿多。快手视频日均播放次数已达150亿次,曝光量可观。在快手广告平台做产品是非常有用的。 短视频流量红利 短视频以拍摄流程简单、制作门槛低、参与性强等特点迅速走...

抖音会限流量吗?如何养号?(老抖音号怎么养号才能精准流量)

抖音会限流量吗?如何养号?(老抖音号怎么养号才能精准流量)

我们不少朋友都在玩抖音,觉得抖音会给自己带来很多流量,那么抖音会限制自己的流量吗?估计和多人在问这个问题,下面就来详细说说如何去养自己的抖音号,如何把自己的流量做起来,学习下吧! 一、先来了解下什么是抖音养号 用一句话概括:就是通过一系列刻意操作来提升自己账号的初始权重。 账号的权重也就是...

如何更改图片尺寸和大小(编辑图片大小格式)

如何更改图片尺寸和大小(编辑图片大小格式)

我们经常需要上传图片至网站,但是常常因为图片的尺寸不符合要求,这时就需要我们修改图片尺寸!很多小伙伴都会选择直接裁剪,但是裁剪是很难拿准尺寸的!下面我们来分享三种快速修改图片尺寸的方法吧!       电脑端:画图...

快手怎么涨粉丝最快(最容易涨粉的短视频)

快手怎么涨粉丝最快(最容易涨粉的短视频)

学会这个方法一周涨粉一万加。 最近我发现在快手上竟然隐藏了一个秘密的涨粉工具,我就用这个方法一周涨了1.1万粉丝。我相信99%的老铁,你最近是不是在怀疑自己的账号有问题?其实你的账号根本就没有任何异常,也不存在任何问题,并且你拍的视频也非常的优秀。 所以大家就不要天天去嫌弃自己...

快手广告投放平台:账户查询模块《NO.3》

快手广告投放平台:账户查询模块《NO.3》

获取快手广告创意信息 请求接口:https://ad.e.kuaishou.com/rest/openapi/v1/creative/list 请求方式:GET/POST 数据格式:JSON 请求参数 快手A...

如何删掉抖音视频上自己发表的作品(教你去掉视频里的水印)

如何删掉抖音视频上自己发表的作品(教你去掉视频里的水印)

抖音是一款非常流行的社交媒体应用程序,用户可以在其中发布自己的作品,包括视频、照片、文字等。如果您想要删除或隐藏自己的作品,可以按照以下步骤进行操作: 1、打开抖音应用程序,并登录您的账号。 点击主页上方的“+”按钮,进入拍摄界面。 点击界面中的“上传”按钮,选择要上传的作品。...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片