帆软指定某个列连续相同的数值合并单元格

最近有个小需求,需要在帆软报表的某个数量列后方展示该列对应某个分组列的合计数,具体类似与这样:

将销售员 孙林 的各个类型产品的销量做汇总,合并单元格后居中展示。

在多个ai工具中搜索的解决方案都是在 单元格属性 模块的 其他模块中,把 连续相同值合并 和 扩展后合并 两个选项勾选中,本人当前的 finereport 设计器版本为 11.0.32,找了一圈确实没找到相关的选项,实在没辙,只好改用js判断来实现。具体如下:

1.通过sql实现数据的汇总,当前用了 sum()over实现

sql 复制代码
select *,
sum(销量)over(partition by 销售员) xl
from 销量

sql结果中,合计行为每行展示

2.把各个字段及表头展示梳理清楚

3.在上方 模板>模板web属性打开,根据实际需求,选择分页或者数据分析打开报表,选择 为该模板单独设置 ,然后在最下方的 事件设置 中选择 加载结束

根据实际情况,修改需要合并的列为哪个,我这里时 F 列,图片中都有标记,将代码直接复制进去就ok。

javascript 复制代码
// 示例:合并B列连续相同单元格
var cells = $("td[id^='F']"); // 选择F列所有单元格
var currentValue = "";
var startIndex = 0;

for (var i = 0; i < cells.length; i++) {
  var cell = $(cells[i]);
  var value = cell.text().trim();
  
  if (value !== currentValue) {
    if (i > startIndex) {
      // 合并从startIndex到i-1的单元格
      cells.eq(startIndex).attr("rowSpan", i - startIndex);
      for (var j = startIndex + 1; j < i; j++) {
        cells.eq(j).hide();
      }
    }
    currentValue = value;
    startIndex = i;
  }
}
// 合并最后一组
if (cells.length > startIndex) {
  cells.eq(startIndex).attr("rowSpan", cells.length - startIndex);
  for (var j = startIndex + 1; j < cells.length; j++) {
    cells.eq(j).hide();
  }
}

最后的结果

结果OK,下课。

相关推荐
一叶飘零_sweeeet17 分钟前
击穿 MySQL 性能天花板:InnoDB Buffer Pool 核心架构、LRU 优化与生产调优全解
数据库·mysql
indexsunny19 分钟前
互联网大厂Java面试实战:从Spring Boot到微服务架构的深度探讨
java·数据库·spring boot·安全·微服务·监控·面试实战
一叶飘零_sweeeet20 分钟前
MySQL InnoDB 锁机制全解:行锁 / 表锁 / 间隙锁 / 临键锁底层逻辑与死锁避坑指南
数据库·mysql
wgzrmlrm7420 分钟前
如何从SQL中提取年份或月份:EXTRACT与日期函数用法
jvm·数据库·python
D4c-lovetrain34 分钟前
linux个人心得23 (mysql②)
数据库·mysql
斌味代码1 小时前
MySQL主从延迟根因诊断法
数据库
逆境不可逃1 小时前
高频 SQL 50 题 之 连接篇 1378 1068 1581 197 1661 577 1280 570 1934
数据库·sql
用户5757303346241 小时前
从 SQL 到对象:Prisma 如何成为全栈开发的“降维打击”利器
数据库
三更两点2 小时前
智能代理工具包:MCP vs. Agent Skills vs. AGENTS.md
数据库·人工智能
丸辣,我代码炸了2 小时前
PostgreSQL 大数据查询与索引优化核心总结
大数据·数据库·postgresql