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

族谱网站开发2008r2网站建设

族谱网站开发,2008r2网站建设,北京专业公司建网站平台,织梦源码网介绍 poi-ooxml 是 Apache POI 项目中的一个库,专门用于处理 Microsoft Office 2007 及以后版本的文件,特别是 Excel 文件(.xlsx 格式)和 Word 文件(.docx 格式)。 在管理系统中需要对数据库的数据进行导…

介绍

poi-ooxml 是 Apache POI 项目中的一个库,专门用于处理 Microsoft Office 2007 及以后版本的文件,特别是 Excel 文件(.xlsx 格式)和 Word 文件(.docx 格式)。

在管理系统中需要对数据库的数据进行导入或导出在系统中经常使用的到。

Java针对MS Office的操作的库屈指可数,比较有名的就是Apache的POI库。这个库异常强大,但是使用起来也并不容易。Hutool针对POI封装一些常用工具,使Java操作Excel等文件变得异常简单。

胡图官网:https://doc.hutool.cn/pages/poi/#%E7%94%B1%E6%9D%A5

Hutool-poi是针对Apache POI的封装,因此需要用户自行引入POI库,Hutool默认不引入。

依赖

<dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.1.2</version>
</dependency><dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.7.18</version>
</dependency>

实体类

支持别名注解的。可以在字段上加@Alias注解。

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("site")
public class Site implements Serializable {private static final long serialVersionUID = 1L;@TableId(value = "id", type = IdType.AUTO)@Alias(value = "编号")private Integer id;@TableField("ip_address")@Alias(value = "IP地址")private String ipAddress;@TableField("source")@Alias(value = "来源")private String source;@TableField("operation")private String operation;@TableField("access_time")private LocalDateTime accessTime;}

在这里插入图片描述

导出Xls

 @GetMapping()public void export(HttpServletResponse response) throws Exception{String fileName = "测试.xls";String encodedFileName = URLEncoder.encode(fileName, "UTF-8");encodedFileName = encodedFileName.replace("+", "%20");  // 处理空格字符List<Site> list = siteService.list();
// 通过工具类创建writer,默认创建xls格式ExcelWriter writer = ExcelUtil.getWriter();// 一次性写出内容,使用默认样式,强制输出标题writer.write(list, true);//response为HttpServletResponse对象response.setContentType("application/vnd.ms-excel;charset=utf-8");//test.xls是弹出下载对话框的文件名response.setHeader("Content-Disposition","attachment;filename="+encodedFileName);ServletOutputStream out=response.getOutputStream();writer.flush(out, true);// 关闭writer,释放内存writer.close();
//此处记得关闭输出Servlet流IoUtil.close(out);}

在这里插入图片描述

导出Xlsx

@GetMapping()
public void export(HttpServletResponse response) throws Exception{String  fileName = URLEncoder.encode("测试.xlsx", "UTF-8").replace("+", "%20");List<Site> list = siteService.list();ExcelWriter writer = ExcelUtil.getWriter(true);writer.write(list, true);response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");response.setHeader("Content-Disposition","attachment;filename="+fileName);ServletOutputStream out=response.getOutputStream();writer.flush(out, true);writer.close();IoUtil.close(out);}

以上都是基于全量数据的导出方法,下面是按需导出。


创建自定义注解

@Retention(RetentionPolicy.RUNTIME) // 保证注解在运行时可访问
public  @interface ExcelTitle {String value(); // 用来保存 Excel 列标题
}

自定义实体类

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("site")
public class Site implements Serializable {private static final long serialVersionUID = 1L;@TableId(value = "id", type = IdType.AUTO)private Integer id;@TableField("ip_address")@ExcelTitle("IP地址")private String ipAddress;@TableField("source")@ExcelTitle("来源")private String source;@TableField("operation")@ExcelTitle("测试字段")private String operation;@TableField("access_time")@ExcelTitle("访问时间")private LocalDateTime accessTime;}

按需不排序

@GetMapping() 
public void export(HttpServletResponse response) throws Exception{// 需要导出的字段名String[] key = {"访问时间", "IP地址", "来源"};// 查找性能较高Set<String> keySet = new HashSet<>(Arrays.asList(key));// 对文件名进行 URL 编码,防止中文字符出现乱码,并将 "+" 替换成 "%20"String fileName = URLEncoder.encode("测试.xlsx", "UTF-8").replace("+", "%20");// 从服务层获取数据列表,通常是从数据库或其他数据源获取List<Site> list = siteService.list();// 创建一个 ExcelWriter 实例,用于写入 Excel 文件,true 表示创建时有表头ExcelWriter writer = ExcelUtil.getWriter(true);// 获取 Site 类的所有字段(反射机制)Field[] fields = Site.class.getDeclaredFields();// 遍历每个字段for (Field field : fields) {// 获取字段上是否有 @ExcelTitle 注解ExcelTitle excelAnnotation = field.getAnnotation(ExcelTitle.class);// 如果字段上存在 @ExcelTitle 注解if (excelAnnotation != null) {// 获取注解中的 value 值(即字段对应的 Excel 标题)String excelValue = excelAnnotation.value();// 判断当前字段的 Excel 标题是否是我们关心的字段if (Arrays.asList(key).contains(excelValue)) {// 如果是我们关心的字段,则添加标题别名(即字段名与 Excel 表头的映射关系)writer.addHeaderAlias(field.getName(), excelValue);}}}// 默认情况下,未添加 alias 的属性也会被写出。如果我们只想输出加了别名的字段,可以调用该方法writer.setOnlyAlias(true);// 将数据写入 Excel 文件,true 表示需要写入表头writer.write(list, true);// 设置响应内容类型为 Excel 文件格式response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");// 设置响应头,指定下载的文件名response.setHeader("Content-Disposition", "attachment;filename=" + fileName);// 获取响应输出流,用于将文件写入客户端ServletOutputStream out = response.getOutputStream();// 将 Excel 内容刷新到输出流writer.flush(out, true);// 关闭 writer 释放资源writer.close();// 关闭输出流IoUtil.close(out);
}

按需排序导出

    @GetMapping()public void export(HttpServletResponse response) throws Exception {String[] key = {"访问时间", "IP地址", "来源"};Set<String> keySet = new HashSet<>(Arrays.asList(key));String fileName = URLEncoder.encode("测试.xlsx", "UTF-8").replace("+", "%20");List<Site> list = siteService.list();ExcelWriter writer = ExcelUtil.getWriter(true);for (String k : key) {String title =  getCharacter(Site.class, k);if(title==null)continue;writer.addHeaderAlias(title, k);}//        //自定义标题别名
//        writer.addHeaderAlias("ipAddress", "IP地址");// 默认的,未添加alias的属性也会写出,如果想只写出加了别名的字段,可以调用此方法排除之writer.setOnlyAlias(true);writer.write(list, true);response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");response.setHeader("Content-Disposition", "attachment;filename=" + fileName);ServletOutputStream out = response.getOutputStream();writer.flush(out, true);writer.close();IoUtil.close(out);}
/*** 根据传入的类和关键字,查找类中具有 @ExcelTitle 注解的字段,* 如果该字段的 @ExcelTitle 注解的 value 属性与传入的关键字匹配,则返回该字段的名称。** @param clazz 目标类的 Class 对象,用于获取类的字段信息。* @param key   需要匹配的关键字,用于查找与其对应的 @ExcelTitle 注解的字段。* @return 如果找到匹配的字段,则返回字段名称;否则返回 null。*/
public String getCharacter(Class<Site> clazz, String key) {// 获取目标类的所有字段Field[] fields = clazz.getDeclaredFields();// 遍历所有字段for (Field field : fields) {// 获取当前字段的 @ExcelTitle 注解ExcelTitle excelAnnotation = field.getAnnotation(ExcelTitle.class);// 如果字段具有 @ExcelTitle 注解if (excelAnnotation != null) {// 获取注解的 value 值String excelValue = excelAnnotation.value();// 检查传入的 key 是否与 @ExcelTitle 注解中的值匹配if (Arrays.asList(key).contains(excelValue)) {// 如果匹配,返回字段名称return field.getName();}}}// 如果没有找到匹配的字段,返回 nullreturn null;
}

在这里插入图片描述


文章转载自:

http://3wtHxpC7.rczrq.cn
http://wCnWXlgK.rczrq.cn
http://lOSsGlRy.rczrq.cn
http://MGz6Cv8S.rczrq.cn
http://P5MfpERK.rczrq.cn
http://docQo200.rczrq.cn
http://RBgRQzqH.rczrq.cn
http://kigA4TUW.rczrq.cn
http://pTOjNqRn.rczrq.cn
http://S586uJa7.rczrq.cn
http://8phwOHS4.rczrq.cn
http://mdWruttg.rczrq.cn
http://0WBCF7iL.rczrq.cn
http://gvSGowUP.rczrq.cn
http://zHsfRkWp.rczrq.cn
http://KfgsF6QE.rczrq.cn
http://mxB8IkF5.rczrq.cn
http://l1xsssx3.rczrq.cn
http://OqEP0b2k.rczrq.cn
http://jBdMwOo3.rczrq.cn
http://B1PAj6OJ.rczrq.cn
http://QG5dyZhA.rczrq.cn
http://JMa3hWym.rczrq.cn
http://9EO9n8Sm.rczrq.cn
http://sb9N5Pf3.rczrq.cn
http://qnsNIfNK.rczrq.cn
http://cm0egQrt.rczrq.cn
http://KctCxmcN.rczrq.cn
http://WYCjHk9Z.rczrq.cn
http://WPI5p3dz.rczrq.cn
http://www.dtcms.com/wzjs/648104.html

相关文章:

  • 网站开发 验收标准广州外贸企业网站建设
  • 街区网站建设的意义房地产开发公司招聘岗位
  • 网站建设在哪里发布长春搜索引擎推广
  • 做网站一天忙吗苏州个人网站制作
  • 提供网站建设公司电话江苏建站管理系统开发
  • 公众号视频网站怎么做河南建设工程一体化
  • 网站建设丿金手指稳定flash可以让网页动起来
  • 如何做网站站长网络营销模式不是孤立存在的
  • 外汇网站建设广西核心关键词seo报价
  • 自然资源网站建设方案jetpack wordpress
  • 网站建设与设计方案余姚的网站建设
  • 网站怎么做宣传微信 网站建设
  • 网站开发武胜招聘十大黄冈网站排行榜
  • 常州市新北区城乡建设局网站公司注册app流程下载
  • 中英文网站建设价格wordpress调用会员等级
  • 深圳建设网站费用SEO网站建设全方位部署
  • 广东建设继续教育网站山西中宇建设集团网站
  • wordpress建立的网站吗wordpress视频无法播放视频播放
  • 安徽省工程建设信息网网站有那个网站可以做免费的投票
  • 酒水食品做的好网站长沙经开区建设局网站
  • 做网站买什么品牌笔记本好企业注册邮箱的步骤
  • 怎么建好网站wordpress加入代码行
  • 有什么网站是做办公家具重庆网站建设行业新闻
  • 为什么企业要建设自己的企业文化金昌网站seo
  • 企业建设网站有哪些做网站价格ihanshi
  • 国外h5制作网站优质网站建设服务
  • 做网站看什么书好做网站免费的域名
  • 建设网站如何赚钱php和wordpress
  • 邯郸做网站最好的公司官方网站平台下载
  • 南宁企业建站程序广告营销公司