java后端读取前端(vue)传过来的excel表格步骤

1.maven导包(两个包的版本号一致)

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.17</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>3.17</version>
</dependency>

2.接收前端发来的请求

@PostMapping("/upload")
// file 为前端发来的文件  file与前端命名一样
ResultJson<Boolean> upload(MultipartFile file) throws IOException {
    Workbook workbook = null;
// 截取文件后缀名
    String suffix = FilenameUtils.getExtension(file.getOriginalFilename());
// excel分为03版本与07版本   07版本后缀名为“xlsx”  03版本后缀为“xls”
    if (suffix.equalsIgnoreCase("xlsx")){
        // 创建07版本的
        workbook = new XSSFWorkbook(file.getInputStream());
    }else {
        // 创建03版本的
        workbook = new HSSFWorkbook(file.getInputStream());
    }
        // workbook.getSheetAt(index) 获取excel中第index个Sheet
    Sheet sheet = workbook.getSheetAt(0);
        // sheet.getLastRowNum()  获取excel中的最后一行行数
    for (int i = 1; i <= sheet.getLastRowNum(); i++){
        // sheet.getRow(i) 获取第i行数据
        Row row = sheet.getRow(i);
        // row.getCell(0) 获取第i行的第一个值
        // getStringCellValue() 将该数据以字符串形式输出
        String name = row.getCell(0).getStringCellValue();
        String phone = row.getCell(1).getStringCellValue();
        String email = row.getCell(2).getStringCellValue();
        String addr = row.getCell(3).getStringCellValue();
        System.out.println(name + "    " + phone + "   " + email + "    " + addr);
    }
    return ResultJson.success(true,"导入成功");
}
  • 5
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前端可以使用FileReader API将Excel文件读取为二进制数据,然后将其发送到后端Java服务器。后端可以使用Apache POI或JExcelAPI等Java库来解析Excel文件并将其转换为数据。以下是一个简单的代码示例: 前端代码: ``` <template> <div> <input type="file" @change="handleFileChange"> </div> </template> <script> export default { methods: { handleFileChange(event) { const file = event.target.files[0] const reader = new FileReader() reader.onload = () => { const data = reader.result this.uploadFile(data) } reader.readAsBinaryString(file) }, uploadFile(data) { // 将数据发送到后端Java服务器 } } } </script> ``` 后端代码: ``` @PostMapping("/upload") public List<List<String>> uploadExcel(@RequestParam("file") MultipartFile file) throws IOException { Workbook workbook = WorkbookFactory.create(file.getInputStream()); Sheet sheet = workbook.getSheetAt(0); List<List<String>> data = new ArrayList<>(); for (Row row : sheet) { List<String> rowData = new ArrayList<>(); for (Cell cell : row) { rowData.add(cell.toString()); } data.add(rowData); } return data; } ``` 这个示例使用Spring Boot和Apache POI来处理Excel文件。在这个例子中,我们将Excel文件作为MultipartFile对象上后端,并使用WorkbookFactory创建一个Workbook对象。然后,我们使用getSheetAt方法获取第一个Sheet对象,并使用for循环遍历每一行和每一列,将每个单元格的值添加到一个字符串列表中,并将该列表添加到数据列表中。最后,我们返回数据列表。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值