抖音资讯

douyinzx

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

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

一、需求说明

通过接口上传一个姓名号码表,返回一个"姓名,号码"格式的的一个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://0291.com.cn/post/42551.html

相关文章

抖音开通小店有什么要求吗?如何做?开抖音小店需要什么条件(抖音小店怎么强制开通)

抖音开通小店有什么要求吗?如何做?开抖音小店需要什么条件(抖音小店怎么强制开通)

  抖音小店是抖音用来变现的主要工具只要,做电商的商家们是肯定不会放过这么大的流量入口的,自从抖音小店推出了以后,越来越多的抖音用户开通抖音小店了,抖音开通小店有什么要求吗?   开通抖音小店有一个前提条件就是已完成抖音企业认证,获得蓝V标识,抖音账号粉丝在30万以上,资质齐全、有淘宝、天猫或...

抖音连赞会是什么后果(抖音被连赞了的补救办法)

抖音连赞会是什么后果(抖音被连赞了的补救办法)

抖音里连赞被限流或者被封号是真的。昨天我自己用小号亲测了,虽然我不是有意的在同一个账号点赞收藏超过了5个视频,我的小号就被封号了,我自己都无法进自己的账号了。以前还不相信以为是谣言,但是我不知道被我无意点赞的博主会不会被限流。   抖音中连续点赞...

搜狗搜索推广怎么收费呢?业务收入逐月下降!

搜狗搜索推广怎么收费呢?业务收入逐月下降!

事实上,搜狗的重点是在第二季度打造业务。其中,搜狗推广优惠活动张朝阳敏锐地发现,现场送货是品牌方直接实现“产品与效果一体化”的一种方式。比如,他在直播“好东西分享”时,可以根据个人推荐的行为,直接“代言”产品质量,投放让产品转化率和品牌影响力大放异彩,进一步吸引更多的大品牌与搜狗合作,如汽车厂商、搜...

抖音如何带货吸引观众?抖音带货吸引观众的方

抖音如何带货吸引观众?抖音带货吸引观众的方

抖音如何带货吸引观众?抖音带货吸引观众的方法 抖音带货如何吸引观众? 1.创造鲜明的人设 越来越多的主播在抖音直播中带来商品,用户的选择也越来越多。要想在众多主播中脱颖而出,就必须有一个鲜明的人设,在这个过程中潜移默化地让用户对你有深刻的记忆,这样才有可能关注你...

快手小店客户端在哪里(快手小店网页版入口查找)

快手小店客户端在哪里(快手小店网页版入口查找)

最近,快手正式上线我的小店新功能啦,有了这个功能大家就可以在快手上赚钱啦,那么快手我的小店怎么开通呢,快快一起来看看下面的相关介绍吧! 快手我的小店怎么开介绍 从目前了解到的信息来看,快手App主播个人主页将新增“快手小店”,每个主播均可开启自己的小店,在快手作品、短视频、直播等场景...

抖音小店好评率低怎么办?抖音店铺好评在哪里?(抖音小店的好评为什么看不到)

抖音小店好评率低怎么办?抖音店铺好评在哪里?(抖音小店的好评为什么看不到)

做电商,商家很看重店铺好评率,不仅如此,消费者购物也会参考店铺的好评量,如果店铺的好评量多,店铺下单量肯定会提升,那抖音小店好评率低怎么办?接下来我们就来给大家讲解一下这方面的内容。 1、保证产品质量 产品是基石。没有好的产品,没有好的售后服务,抖音店铺好评率是没有办法涨起来的。客...

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

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