当前位置: 首页 > news >正文

网站运维公司建设银行网站设置密码

网站运维公司,建设银行网站设置密码,厦门百度搜索网站排名,企业网站建设的步骤过程一、Easyexcel 简介 EasyExcel是一个基于Java的Excel处理工具库,它的核心设计理念是快速、简洁,并且能够有效解决处理大文件时的内存溢出问题。使用EasyExcel,开发者可以在几乎不需要考虑性能和内存消耗的情况下,轻松实现Excel文…

一、Easyexcel 简介

EasyExcel是一个基于Java的Excel处理工具库,它的核心设计理念是快速、简洁,并且能够有效解决处理大文件时的内存溢出问题。使用EasyExcel,开发者可以在几乎不需要考虑性能和内存消耗的情况下,轻松实现Excel文件的读写操作。

  • Easyexcel 官方文档:https://easyexcel.opensource.alibaba.com/docs/current/
  • github地址:https://github.com/alibaba/easyexcel
  • gitee地址:https://gitee.com/easyexcel/easyexcel

二、为何选择 Easyexcel

1. 现有框架的问题

  • Apache POI 和 jxl: 这两个Java框架用于解析和生成Excel文件,但它们的主要问题是内存消耗大。
  • 内存溢出问题: 处理大型Excel文件时,这些框架可能会消耗大量内存,导致内存溢出。

2. Apache POI 的局限性

  • SAX模式: Apache POI 提供了SAX模式的API来部分解决内存问题,但仍然存在不足。
  • 内存消耗: 即使使用SAX模式,Apache POI 在处理Excel 2007版(.xlsx)文件时,由于解压缩和存储过程在内存中进行,内存消耗依然很大。

3. EasyExcel 的优势

  • 重写解析: EasyExcel 重写了Apache POI对Excel 2007版的解析方式,显著降低了内存消耗。
  • 内存优化: 一个3MB的Excel文件在使用Apache POI的SAX模式解析时可能需要约100MB内存,而EasyExcel可以将内存需求降低到几MB。
  • 大文件处理: 使用EasyExcel,即使更大的Excel文件也不会导致内存溢出。
  • 03版Excel处理: 对于Excel 2003版(.xls),EasyExcel依赖于Apache POI的SAX模式,并在此基础上进行了模型转换封装,使得使用更加简单和方便。

三、Springboot 项目集成 EasyExcel

1. pom 文件引入依赖:

<dependency>  <groupId>com.alibaba</groupId>  <artifactId>easyexcel</artifactId>  <version>3.1.0</version> <!-- 请检查并使用最新版本 -->  
</dependency>

2. 实体类(例如 UserData)

import com.alibaba.excel.annotation.ExcelProperty;  public class UserData {  @ExcelProperty(value = "ID", index = 0)  private Integer id;  @ExcelProperty(value = "姓名", index = 1)  private String name;  @ExcelProperty(value = "年龄", index = 2)  private Integer age;  // 省略 getter 和 setter 方法  // ...  
}

3. EasyExcel 操作帮助类

import com.alibaba.excel.EasyExcel;  
import com.alibaba.excel.context.AnalysisContext;  
import com.alibaba.excel.event.AnalysisEventListener;  
import com.alibaba.excel.read.builder.ExcelReaderBuilder;  
import com.alibaba.excel.read.builder.ExcelReaderSheetBuilder;  
import com.alibaba.excel.write.builder.ExcelWriterBuilder;  
import com.alibaba.excel.write.builder.ExcelWriterSheetBuilder;  
import com.alibaba.excel.write.metadata.WriteSheet;  import org.springframework.web.multipart.MultipartFile;  import java.io.ByteArrayInputStream;  
import java.io.ByteArrayOutputStream;  
import java.io.IOException;  
import java.io.InputStream;  
import java.util.ArrayList;  
import java.util.List;  public class EasyExcelUtils {  // 导出 Excel  public static byte[] exportExcel(List<?> data, String sheetName, Class<?> head) {  try (ByteArrayOutputStream out = new ByteArrayOutputStream()) {  ExcelWriterBuilder writerBuilder = EasyExcel.write(out, head);  ExcelWriterSheetBuilder sheetBuilder = writerBuilder.sheet(sheetName);  WriteSheet writeSheet = sheetBuilder.build();  EasyExcel.write(out, data, writeSheet).finish();  return out.toByteArray();  } catch (IOException e) {  throw new RuntimeException("导出 Excel 失败", e);  }  }  // 导入 Excel  public static <T> List<T> importExcel(MultipartFile file, Class<T> clazz) {  try (InputStream inputStream = file.getInputStream()) {  ExcelReaderBuilder readerBuilder = EasyExcel.read(inputStream, clazz, new AnalysisEventListener<T>() {  private List<T> list = new ArrayList<>();  @Override  public void invoke(T data, AnalysisContext context) {  list.add(data);  }  @Override  public void doAfterAllAnalysed(AnalysisContext context) {  // 数据解析完成后,可以在这里处理解析结果  }  });  ExcelReaderSheetBuilder sheetBuilder = readerBuilder.sheet();  sheetBuilder.doRead();  return list;  } catch (IOException e) {  throw new RuntimeException("导入 Excel 失败", e);  }  }  // 其他可能需要的帮助方法...  
}

4. 在 Controller 中使用

import org.springframework.http.HttpHeaders;  
import org.springframework.http.MediaType;  
import org.springframework.http.ResponseEntity;  
import org.springframework.web.bind.annotation.GetMapping;  
import org.springframework.web.bind.annotation.PostMapping;  
import org.springframework.web.bind.annotation.RequestParam;  
import org.springframework.web.bind.annotation.RestController;  
import org.springframework.web.multipart.MultipartFile;  import java.util.Arrays;  
import java.util.List;  @RestController  
public class ExcelController {  @PostMapping("/exportExcel")  public ResponseEntity<byte[]> exportExcel() {  List<UserData> data = Arrays.asList(  new UserData(1, "Alice", 25),  new UserData(2, "Bob", 30),  new UserData(3, "Charlie", 35)String fileName = "users.xlsx";  byte[] excelBytes = EasyExcelUtils.exportExcel(data, fileName, UserData.class);  HttpHeaders headers = new HttpHeaders();  headers.setContentDispositionFormData("attachment", fileName);  headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);  return ResponseEntity.ok()  .headers(headers)  .body(excelBytes);  }  @PostMapping("/importExcel")  public ResponseEntity<?> importExcel(@RequestParam("file") 		MultipartFile file) {  List<UserData> userDataList = EasyExcelUtils.importExcel(file, UserData.class);  // 假设你需要在这里处理导入的数据,比如保存到数据库等  // ...  return ResponseEntity.ok("Excel 导入成功,共导入 " + userDataList.size() + " 条数据");  
}

四、前端 vue 页面调用示例

<script>  
import axios from 'axios';  export default {  // ... 其他选项和数据 ...  methods: {  exportExcel() {  // 假设你有一个要发送到服务器的对象(如果需要的话)  const params = {  // 例如: filter: 'someValue'  };  axios({  method: 'post',  url: '/api/exportExcel', // 修改为你的实际API地址  data: params, // 如果需要的话  responseType: 'blob', // 告诉axios我们期望返回一个blob  })  .then((response) => {  // 创建一个Blob对象来表示二进制数据  const blob = new Blob([response.data], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' });  // 创建一个指向该Blob对象的URL  const url = window.URL.createObjectURL(blob);  // 创建一个a标签并模拟点击来下载文件  const link = document.createElement('a');  link.href = url;  link.setAttribute('download', 'users.xlsx'); // 设置下载文件名  document.body.appendChild(link);  link.click();  // 清理  window.URL.revokeObjectURL(url);  document.body.removeChild(link);  })  .catch((error) => {  console.error('导出Excel失败:', error);  this.message = '导出Excel失败';  });  },  // ... 其他方法 ...  },  
};  
</script>
http://www.yayakq.cn/news/370746/

相关文章:

  • 网站建设一条龙ue365什么是网络营销?
  • 如何做php网站建设河北网站备案 多长时间通过
  • 全国建设厅网站字体设计在线生成
  • 尼尔的h版是那个网站做的青岛标志设计公司
  • o2o网站建设代理商wordpress 会员插件
  • 广州微信网站建设价格静态网站建设的技术运用
  • 哪家公司的网站做得好手做网站
  • wordpress需要先安装数据库优化大师安卓版
  • 做网站引流的利润推荐中山精品网站建设
  • 网站页面设计说明书做的网站怎样适配手机
  • 网站怎么做反向代理网站模板论坛
  • 巩义网站建设与制作最新互联网企业排名
  • 网站的盈利点如何做一个大型网站
  • 自媒体135网站免费下载安装王烨涛
  • 网站备案中是什么意思服务器安全模式怎么进
  • 个人网站需要哪些内容wordpress 显示当前分类
  • seo是什么职业济南优化官网公司
  • 扁平化网站设计教程网站这么推广
  • 什么叫网站收录企业的vi设计系统
  • 网站修改需要什么wordpress获取自定义类型文章
  • dw做网站怎么跳转冒用网站备案号建设网站
  • 中国建设银行东营分行网站济南协会网站设计团队
  • 深圳网站建设 乐云seo网址大全黄页男女免费
  • 南宁网站建设流程网站建设后应该干什么
  • 海口建站网站模板网站建设与熊掌号未来的关系
  • 平邑哪里有做网站的天津网站设计哪家公司好
  • 电子产品展示网站模板杭州市临安区建设局网站
  • 建网站代理哪个图片制作器在线制作
  • 做网站软件ps网站搭建三部曲是什么?
  • 中国建设银行北京天竺支行网站消费全返的 微网站开发