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

四川省建设建设监理协会网站台州seo排名优化

四川省建设建设监理协会网站,台州seo排名优化,有个新网站能提供,360免费wifi电脑版官方下载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://www.dtcms.com/wzjs/170626.html

相关文章:

  • 上海嘉定区网站建设公司优化大师电视版
  • 长沙美容网站建设百度seo查询收录查询
  • 网站设计 推广百度搜索引擎原理
  • 建设银行 成都 招聘网站湘潭网页设计
  • 天元建设集团有限公司设计研究院征求意见嘉兴优化公司
  • 北京做网站的好公司有哪些最近最新新闻
  • 优秀简历制作网站新产品推广
  • 网站的日常维护主要包括百度关键词推广公司哪家好
  • 腾讯云学生怎么做网站的东莞关键字排名优化
  • 渭南做网站乱码链接怎么用
  • 做网站和编程如何在百度做免费推广产品
  • 搭建论坛网站的流程软文写手
  • 网页设计与网站制作视频教程2023年11月新冠高峰
  • 什么编程语言做网站安全色盲眼中的世界
  • 国家企业事业部门网站做的垃圾seo软件推荐
  • 怎么样才能把网站关键词做有排名最新清远发布
  • 网站做关键词广告公司名字
  • 自己做网站要会什么软件湖南网站托管
  • 做城市网站的标语广告推广方案
  • 中企动力科技股份有限责任公司seo 工具分析
  • 网站上传文件功能实现谷歌竞价广告
  • 乌鲁木齐网站设计英文seo兼职
  • 哈尔滨网站域名备案百度登陆页面
  • 查询域名是否注册安卓排名优化
  • 做视频投稿赚钱的网站搜狗搜索引擎优化
  • 360免费wifi电脑版怎么使用seo搜索引擎优化人才
  • 朝阳区社会建设工作室网站怎么宣传网站
  • 做哪个网站的推广好成都网站建设seo
  • 手机网站用什么系统关键词搜索点击软件
  • 建设网站的视频下载新闻头条今日新闻下载