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

济南微信网站开发百度排名点击软件

济南微信网站开发,百度排名点击软件,公司和个人均不能备案论坛类网站,网页版梦幻西游踏青寻柳攻略文章目录 一、背景二、实现1、写法一2、写法二 三、遇到的问题四、参考 一、背景 近期开发的一个新功能需要导出和前端展示样式一致的统计表格,而前端使用的elementui的table组件,show-summary属性选择后可以自动计算。后端导出时其他单元格与返回前端展…

文章目录

    • 一、背景
    • 二、实现
      • 1、写法一
      • 2、写法二
    • 三、遇到的问题
    • 四、参考

一、背景

近期开发的一个新功能需要导出和前端展示样式一致的统计表格,而前端使用的elementui的table组件,show-summary属性选择后可以自动计算。后端导出时其他单元格与返回前端展示时一致,但最后一行的合计行需要后端计算并填充。

二、实现

1、写法一

可以参考issue中填充模板形式,代码略。

2、写法二

由于表头和行数量是动态的,我是采取构造dataList和header的方式,未读取模板文件。部分逻辑为伪代码。

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.metadata.data.FormulaData;
import com.alibaba.excel.metadata.data.WriteCellData;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.google.common.collect.Lists;
import org.apache.poi.ss.usermodel.Workbook;import java.util.List;public class ExcelTest {public void download() {try {ExcelWriter excelWriter = EasyExcel.write("需要生成的文件名.xlsx").inMemory(true).build();WriteSheet mainSheet = EasyExcel.writerSheet(0, "需要写入的sheet名").head(buildHeadTitles("123")).build();excelWriter.write(buildData("123"), mainSheet);Workbook workbook = excelWriter.writeContext().writeWorkbookHolder().getWorkbook();workbook.setForceFormulaRecalculation(true);workbook.getCreationHelper().createFormulaEvaluator().evaluateAll();excelWriter.finish();// 传给前端的相关逻辑} catch (Exception e) {// 异常处理}}private List<List<String>> buildHeadTitles(String targetId) {// 构建动态表头,相邻两个同名表头会默认合并// 这里的Lists是com.google.guava下的 com.google.common.collect.ListsList<List<String>> headTitles = Lists.newArrayList();// 第一列headTitles.add(Lists.newArrayList("团队统计", "姓名", "姓名"));headTitles.add(Lists.newArrayList("团队统计", "机构名称", "机构名称"));// 查询并类似上面格式添加动态列headTitles.add(Lists.newArrayList("团队统计", "分类1", "动态列1"));return headTitles;}private List<List<Object>> buildData(String targetId) {ListList<Object>> dataList = Lists.newArrayList();// 循环塞数据行 =========== 循环开始// 最后一行塞数据的其中一个单元格公式示例如下// 在前面构造的公式字符串List<Object> list = new ArrayList<>():// 先塞其他数据list.add("syz");list.add("顶级机构");list.add("1");String formulaStr = "SUM(VALUE(D4),VALUE(E4),VALUE(F4))";WriteCellData<String> formula = new WriteCellData<>();FormulaData formulaData = new FormulaData();formula.setFormulaData(formulaData);formulaData.setFormulaValue(formulaStr);list.add(formula);dataList.add(list)// ============= 循环结束return dataList;}
}

三、遇到的问题

  • 需要注意的是只有3.0.0+版本,才包含WriteCellData类,以及对应的formulaData的内部类,workbook相关的计算属性才会被调用,否则不会生效。此前2.0.0+的版本,找了半天设置未生效原因,翻了下workbook设置源码和相关issue才发现。
  • 计算序号与字母转换时可以善用hutool工具包的ExcelUtil,已提供了序号到字母的转换,从0开始,如0-A,1-B。。。26-AA。。。等等,便于公式计算行和列。

四、参考

https://easyexcel.opensource.alibaba.com/docs/current/quickstart/write
https://github.com/alibaba/easyexcel/issues/3242
https://github.com/alibaba/easyexcel/issues/1464

http://www.tj-hxxt.cn/news/53791.html

相关文章:

  • 设计师经常上的网站国外seo网站
  • 张家港早晨网站制作描述优化方法
  • 教育系统网站备案艺术培训学校招生方案
  • 怎么做微帮网站女教师遭网课入侵直播录屏曝光视频
  • 网页网站设计公司有哪些百度推广账户怎么开
  • 中国八冶建设集团网站抖音seo查询工具
  • 门户网站分类最近七天的新闻大事
  • 张家口全景网站建设seo排名专业公司
  • 银行需要网站开发人员嘛网络营销的概念及特征
  • 可以为自己的小说建设网站软文世界
  • 可以做设计的网站有哪些郑州整站网站优化
  • wordpress邮箱宁波seo网络推广外包报价
  • 温州网站建设推荐广州seo招聘信息
  • wordpress 垃圾评论seo优化服务是什么
  • 可以免费做兼职的网站有哪些安卓优化大师旧版本下载
  • 外链博客网站运营怎么做
  • 平面设计师工作内容关键词优化的发展趋势
  • 做网站申请域名的流程企业整站优化
  • wordpress订阅邮箱正规的关键词优化软件
  • 企业做网站的作用一媒体app软件下载老版本
  • 在线企业查询系统杭州seo排名
  • 佛山做网站哪家好seo霸屏
  • 多少钱日语优化网站内容
  • 株洲有名的网站天津网络广告公司
  • 电子商务网站建设与原理关键词搜索爱站
  • 怎么制作网站app360网站收录提交
  • 大型做网站公司推特最新消息今天
  • 做网站条件网络营销产品策略分析
  • 手机建站系统源码螺蛳粉营销策划方案
  • jquery 单击input输入框弹出选择框多用于人才类网站怎么推广产品