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

新手做网站最简单流程抚州南城网站建设

新手做网站最简单流程,抚州南城网站建设,包头市住房与城乡建设部网站,wordpress 开发视频总结#xff1a;目前市面上流行的2种 EasyExcel和POI都不是真正的对物理excel文件进行追加导入。只是在缓存里面追加#xff0c;最后一次性写入#xff0c;并不能解决内存占用问题。 1.EasyExcel2.POI3.CSV 无非就是下面两种逻辑#xff1a; 1.for循环查询数据#xff0c;… 总结目前市面上流行的2种 EasyExcel和POI都不是真正的对物理excel文件进行追加导入。只是在缓存里面追加最后一次性写入并不能解决内存占用问题。 1.EasyExcel2.POI3.CSV 无非就是下面两种逻辑 1.for循环查询数据将数据写入缓存最后一次性写入excel。 2.将已有的excel通过FIleInputStream流读出来加载到内存当中然后获取对应sheet页的行数进行追加操作。 PS建议使用CSV文件格式直接使用Java原生的FileUtils追加写入 FileUtils.writeStringToFile(file, sb.toString(), GBK, true);下面来讲讲easyExcel、POI、csv相关的代码写法 要求 1.对表头进行排序过滤 2.对列进行排序过滤1.EasyExcel 官网地址EasyExcel官网 我们使用新版本的旧的对于字段排序/过滤都不支持dependencygroupIdcom.alibaba/groupIdartifactIdeasyexcel/artifactIdversion3.3.2/version/dependency//此为线程池异步导出 commonExecutor.execute(() - {File file null;ExcelWriter excelWriter null;try {file File.createTempFile(a, .xlsx);file.deleteOnExit();excelWriter EasyExcel.write(file, UserVO.class).head(headlist) // 表头传入一个list集合.includeColumnFieldNames(showColumnList) // 对于UserVO要展示的列集合.orderByIncludeColumn(true) // 是否根据showColumnList集合的顺序排序.autoCloseStream(true) // 自动关闭流.build();WriteSheet writeSheet EasyExcel.writerSheet(Sheet1).build();// 循环 200/页查询数据int pageNum 1;int pageSize 200;while (true) {ListUserVO voList getData(pageNum, pageSize); // getData根据业务实现// 将数据写入临时文件 此处循环追加就是写到内存里面excelWriter.write(voList , writeSheet);if (pageNum * pageSize count) {break;}pageNum;}// 数据处理完毕后刷盘写入物理文件excelWriter.finish();} catch (Exception e) {log.error(导出 异常: e.getMessage(), e);} finally {// 删除临时文件if (!Objects.isNull(file)) {file.delete();}} });2.POI 网传SXSSFWorkbook可以实现追加写入然后实操后其实是覆盖写入。 //SXSSFWorkbook 和 XSSFWorkbook 都差不多只是定义不同写法都差不多import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.streaming.SXSSFWorkbook;import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.util.List;public class ExcelAppender {public static void main(String[] args) {String filePath C:\\Local\\Temp\\11.xlsx;// 构造一个查询数据的列表ListString queryDataList List.of(query4, query5, query6);// 加载已存在的 Excel 文件try (Workbook workbook new SXSSFWorkbook(new FileInputStream(new File(filePath)))) {Sheet sheet workbook.getSheetAt(0);// 获取已存在数据的最后一行索引int lastRowNum sheet.getLastRowNum();// 在最后一行索引的下一行开始追加写入查询数据int rowNum lastRowNum 1;for (String queryData : queryDataList) {Row row sheet.createRow(rowNum);Cell cell row.createCell(0);cell.setCellValue(queryData);}// 保存修改后的工作簿到文件try (FileOutputStream outputStream new FileOutputStream(new File(filePath))) {workbook.write(outputStream); System.out.println(查询数据已覆盖写入到 Excel 文件 filePath);} catch (IOException e) {e.printStackTrace();}} catch (IOException e) {e.printStackTrace();}} }3.CSV 来写我最终选择的写法CSV就是追加物理文件数据。很不错。 commonExecutor.execute(() - {File temp null;try {temp File.createTempFile(aaa, .csv);temp.deleteOnExit();ListListString fillData new ArrayList();// 1.初始化表头showNameList是表头集合有顺序的哈~fillData.add(ImmutableList.of(showNameList.toString()));// 2.循环 200/页查询数据int pageNum 1;int pageSize 200;while (true) {ListUserVO recordVOList getData(pageNum, pageSize);// 3.填充业务数据 我用的反射fillData.addAll(ExcelUtil.convertSortEntityListToDataList(showColumnList, recordVOList));StringBuilder sb new StringBuilder();for (ListString rowData : fillData) {sb.append(String.join(,, rowData));sb.append(System.lineSeparator());}try {FileUtils.writeStringToFile(temp, outPutStr, GBK, true);} catch (IOException e) {log.error(写入CSV 异常:{}, e.getMessage(), e);return;}if (pageNum * pageSize count) {break;}pageNum;fillData.clear();}} catch (Exception e) {log.error(导出 异常:{}, e.getMessage(), e);} finally {// 4.删除临时文件if (!Objects.isNull(temp)) {temp.delete();}} });当然会存在一定的问题比如csv文件打开时office全家桶会把日期格式转换比如 “2024-01-04 14:28:29” - “2024/1/4 14:28:29” 就看大家能不能接受了。
http://www.ho-use.cn/article/10820260.html

相关文章:

  • 百度网站降级的原因淘宝网站开发框架
  • 轻量应用服务器可以做网站吗皮肤科在线医生免费咨询
  • 汉中公司做网站微网站建设是什么
  • 接网站制作网站建设与推广的策划方案
  • 个人如何申请网站合肥网站排名推广
  • 岳阳市规划局建设工程公示网站设计机构
  • 吉林市网站制作哪家好免费网站源码建站系统
  • 西宁网站公司张家界网站制作
  • 建设中标查询网站中企动力做网站 知乎
  • 机械网站开发方案苏州网站建设教程
  • 郑州网站推广排名wordpress编辑写文章失败
  • 网站建设项目实践报告书网络seo优化平台
  • cookie做网站访问量wordpress自动抓取
  • 免费货源在线网站跨境电商平台开发
  • 产品展示网站方案网站建设工作策划方案
  • 最新网站建设高端个人网站
  • 山亭建设局网站58同城做网站被骗
  • 建筑资料网站大全如何简单制作生理盐水
  • 公司企业免费网站系统查找北京国互网网站建设
  • 做招聘信息的网站有哪些做博客网站怎么赚钱
  • 电商网站首页图片郑州建网站
  • wordpress多站点不同主题微营销
  • 网站导航条图片素材wordpress首页设置成文章还是页面
  • 做网站的合同范文怎么做网页中不显示项目符号
  • 自己搭建网站怎么搭建有域名了如何建设网站
  • 做网站可以没有框架吗宣城市建设监督管理局网站首页
  • 做网站常见问题模板纳米加工平台
  • 重庆网站制作设计网站动画效果怎么做
  • 视频会议系统直播聊天网站开发建设游戏运营网站开展工作内容
  • 多用户旅游网站开发如何建设淘宝客网站