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

中国工程建设标准化网站凡客诚品app找不到了

中国工程建设标准化网站,凡客诚品app找不到了,wordpress更换头像插件,余姚公司网站建设1.easyexcel EasyExcel是一个基于ava的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel 即通过java完成对excel的读写操作&#xff0c; 上传下载 2.easyexcel写操作 把java类中的对象写入到excel表格中 步骤 1.引入依赖 <depen…

1.easyexcel

EasyExcel是一个基于ava的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel

即通过java完成对excel的读写操作,        上传下载

2.easyexcel写操作

把java类中的对象写入到excel表格中

步骤

1.引入依赖

<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>4.0.0</version>
</dependency>
<dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><!-- 这个版本可以继续往上升 ,但是不要低于这个 --><version>2.15.0</version>
</dependency>

2.封装相应的对象

@Data
@AllArgsConstructor
@NoArgsConstructor
public class ExcelDemo {@ExcelProperty(value = "姓名")private String name;@ExcelProperty(value = "年龄")private Integer age;@ExcelProperty(value = "性别")private String sex;//标记该属性不写入exccel表格中@ExcelIgnoreprivate String address;
}

3.通过easyexcel写入

测试类

package com.ghx;import com.alibaba.excel.EasyExcel;
import com.ghx.excel.ExcelDemo;import java.util.ArrayList;
import java.util.List;/*** @author :guo* @date :Created in 2025/2/14 17:19* @description:* @version:*/
public class TestWriterDemo {public static void main(String[] args) {//fileName:excel文件所在的路径及名称String fileName = "D:\\AAAAAA\\javamaven\\boot\\demoeasy\\easyExcel01.xlsx";List<ExcelDemo> data=new ArrayList<>();data.add(new ExcelDemo("小明", 18, "男", "北京"));data.add(new ExcelDemo("小李", 19, "女", "上海"));data.add(new ExcelDemo("小刚", 20, "男", "深圳"));data.add(new ExcelDemo("小文", 21, "女", "广州"));// 这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭EasyExcel.write(fileName, ExcelDemo.class).sheet("测试1").doWrite(data);}
}

web端

package com.ghx.controller;import com.alibaba.excel.EasyExcel;
import com.ghx.excel.ExcelDemo;
import jakarta.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;import java.io.IOException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;/*** @author :guo* @date :Created in 2025/2/14 20:01* @description:* @version:*/
@Controller
public class ExcelController {@GetMapping("download")public void download(HttpServletResponse response) throws IOException {// 这里注意 有同学反应使用swagger 会导致各种问题,请直接用浏览器或者用postmanresponse.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("utf-8");// 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系String fileName = URLEncoder.encode("web测试", "UTF-8").replaceAll("\\+", "%20");response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");List<ExcelDemo> data=new ArrayList<>();data.add(new ExcelDemo("小明", 18, "男", "北京"));data.add(new ExcelDemo("小李", 19, "女", "上海"));data.add(new ExcelDemo("小刚", 20, "男", "深圳"));data.add(new ExcelDemo("小文", 21, "女", "广州"));EasyExcel.write(response.getOutputStream(), ExcelDemo.class).sheet("模板").doWrite(data);}
}

3.easyexcel读操作

1.监听器

package com.ghx.excel;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.read.listener.ReadListener;
import com.alibaba.excel.util.ListUtils;
import com.alibaba.fastjson.JSON;
import com.ghx.excel.DemoDAO;
import com.ghx.excel.ExcelDemo;
import lombok.extern.slf4j.Slf4j;import java.util.List;// 有个很重要的点 DemoDataListener 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去
@Slf4j
public class DemoDataListener implements ReadListener<ExcelDemo> {/*** 每隔5条存储数据库,实际使用中可以100条,然后清理list ,方便内存回收*/private static final int BATCH_COUNT = 100;/*** 缓存的数据*/private List<ExcelDemo> cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);/*** 假设这个是一个DAO,当然有业务逻辑这个也可以是一个service。当然如果不用存储这个对象没用。*/private DemoDAO demoDAO;public DemoDataListener() {// 这里是demo,所以随便new一个。实际使用如果到了spring,请使用下面的有参构造函数demoDAO = new DemoDAO();}/*** 如果使用了spring,请使用这个构造方法。每次创建Listener的时候需要把spring管理的类传进来** @param demoDAO*/public DemoDataListener(DemoDAO demoDAO) {this.demoDAO = demoDAO;}/*** 这个每一条数据解析都会来调用** @param data    one row value. Is is same as {@link AnalysisContext#readRowHolder()}* @param context*/@Overridepublic void invoke(ExcelDemo data, AnalysisContext context) {System.out.println("解析到一条数据:{}"+JSON.toJSONString(data));cachedDataList.add(data);// 达到BATCH_COUNT了,需要去存储一次数据库,防止数据几万条数据在内存,容易OOMif (cachedDataList.size() >= BATCH_COUNT) {saveData();// 存储完成清理 listcachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);}}/*** 所有数据解析完成了 都会来调用** @param context 最后执行的代码*/@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {// 这里也要保存数据,确保最后遗留的数据也存储到数据库saveData();System.out.println("所有数据解析完成!");}/*** 加上存储数据库*/private void saveData() {System.out.println("{}条数据,开始存储数据库!"+cachedDataList.size());demoDAO.save(cachedDataList);System.out.println("存储数据库成功!");}
}

2.

package com.ghx.excel;import java.util.List;/*** 假设这个是你的DAO存储。当然还要这个类让spring管理,当然你不用需要存储,也不需要这个类。**/
@Component
public class DemoDAO {public void save(List<ExcelDemo> list) {// 如果是mybatis,尽量别直接调用多次insert,自己写一个mapper里面新增一个方法batchInsert,所有数据一次性插入}
}

3.测试

package com.ghx;import com.alibaba.excel.EasyExcel;
import com.ghx.excel.DemoDataListener;
import com.ghx.excel.ExcelDemo;/*** @author :guo* @date :Created in 2025/2/14 20:24* @description:* @version:*/
public class TestReadDemo {public static void main(String[] args) {String fileName = "D:\\AAAAAA\\javamaven\\boot\\demoeasy\\easyExcel01.xlsx";// 这里默认读取第一个sheetEasyExcel.read(fileName, ExcelDemo.class, new DemoDataListener()).sheet().doRead();}
}

 web版

1.文件上传依赖

<dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.5</version>
</dependency>

2.controller
 

package com.ghx.controller;import com.alibaba.excel.EasyExcel;
import com.ghx.excel.DemoDAO;
import com.ghx.excel.DemoDataListener;
import com.ghx.excel.ExcelDemo;
import jakarta.servlet.http.HttpServletResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;import java.io.IOException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;/*** @author :guo* @date :Created in 2025/2/14 20:01* @description:* @version:*/
@Controller
public class ExcelController {@Autowiredprivate DemoDAO demoDAO;@GetMapping("download")public void download(HttpServletResponse response) throws IOException {// 这里注意 有同学反应使用swagger 会导致各种问题,请直接用浏览器或者用postmanresponse.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("utf-8");// 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系String fileName = URLEncoder.encode("web测试", "UTF-8").replaceAll("\\+", "%20");response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");List<ExcelDemo> data=new ArrayList<>();data.add(new ExcelDemo("小明", 18, "男", "北京"));data.add(new ExcelDemo("小李", 19, "女", "上海"));data.add(new ExcelDemo("小刚", 20, "男", "深圳"));data.add(new ExcelDemo("小文", 21, "女", "广州"));EasyExcel.write(response.getOutputStream(), ExcelDemo.class).sheet("模板").doWrite(data);}@PostMapping("upload")@ResponseBodypublic String upload(MultipartFile file) throws IOException {EasyExcel.read(file.getInputStream(), ExcelDemo.class, new DemoDataListener(demoDAO)).sheet().doRead();return "success";}
}

测试


文章转载自:

http://lSet1wv6.kxqfz.cn
http://0iDMiTAZ.kxqfz.cn
http://OG3FOkc7.kxqfz.cn
http://kH32QclS.kxqfz.cn
http://dppBhKIQ.kxqfz.cn
http://uyDrGI7v.kxqfz.cn
http://JdV4C1za.kxqfz.cn
http://QNdxDaVU.kxqfz.cn
http://uXH30412.kxqfz.cn
http://pr3Ovixs.kxqfz.cn
http://z4Z1NBPV.kxqfz.cn
http://WWRqEiGL.kxqfz.cn
http://lrnbXq7n.kxqfz.cn
http://BQw9kW5Q.kxqfz.cn
http://DryAOhip.kxqfz.cn
http://Xfyc5igP.kxqfz.cn
http://5NHDjAAd.kxqfz.cn
http://xGaukJse.kxqfz.cn
http://QMkcyXlX.kxqfz.cn
http://wwVSrmbv.kxqfz.cn
http://zTp4xHCa.kxqfz.cn
http://a1FHD8jo.kxqfz.cn
http://ua9p3Njp.kxqfz.cn
http://GRj4DcP1.kxqfz.cn
http://a4e940rN.kxqfz.cn
http://dWFMArRS.kxqfz.cn
http://84NbrWrQ.kxqfz.cn
http://slfxvt2s.kxqfz.cn
http://3fKPq01H.kxqfz.cn
http://ZFJcEtGP.kxqfz.cn
http://www.dtcms.com/wzjs/705027.html

相关文章:

  • 成都企业网站排名优化有经验的做网站
  • 常德网络建站免费申请试用网站
  • 免费的素材网站推荐打开网页就是2345网址导航
  • 黑龙江省生产建设兵团知青网站网站设计的可行性分析
  • 自已如何建网站保姆给老人做爰神马网站
  • 最好科技广州网站建设网站下载视频软件
  • 网站页面做专题的步骤做一个公众号多少钱
  • 做翻译小说网站赚钱吗哈尔滨网站建设教程
  • 做gif有什么网站7154电商平台官网
  • 网站首页设计说明深圳市住建局官网查询
  • 洛江区住房和城乡建设局网站做时间轴的在线网站
  • 怎么做和美团一样的网站第一模板网站
  • 全球最大设计网站成品短视频app下载有哪些软件可以用
  • 百度竞价 百度流量 网站权重c2c代表性企业网站
  • 公司新成立想要搭建网站怎么做信阳公司网站建设
  • 湖北网站建设怎样课件app制作教程
  • 哪里可以做免费的物流网站网络规划设计师思维导图
  • 什么不属于网站推广软件微信小程序模板样式
  • 做直播网站要多少钱网站建设合同怎么写
  • 国外html5网站模板黄冈免费网站建设平台
  • 网站中的滑动栏怎么做的深圳seo论坛
  • 玉溪做网站百度指数查询手机版
  • 珠海教育局系统网站怎么建设公益网站
  • 网站域名到期会怎么样合肥装修
  • 建设厅电工证查询网站广州市做网站
  • 上高县城乡规划建设局网站网站建设好怎么发布
  • 做游戏网站在哪里找wordpress后台地址
  • 网站图片设置教程wordpress 店铺插件
  • 红色大气网络公司企业网站源码_适合广告设计泰安新浪乐居房产网
  • 成都建网站公司电话改 wordpress 主题 颜色