反馈已提交

网络繁忙

多级序号

  • 文档创建者:axing
  • 历史版本:3
  • 最近更新:Leo.Tsai 于 2020-05-07
  • 1. 概述

    1.1 预期效果

    在设计报表的时候,可能需要根据多列数据生成多级序号,效果如下图所示:

    image.png

    1.2 实现思路

    先获取第一列数据当前值在当前列数据去重后的序号.

    再获取第二列数据当前值在(当前列数据去重后且第一列数据等于当前第一列的值)的序号。

    对分别获取到的序号进行拼接。

    2. 示例

    2.1 数据准备

    新建数据集 ds1,数据库查询语句为:SELECT * FROM 部门

    image.png

    2.2 报表设计

    1)如下图设计表格样式,B2 数据设置为列表,A2 左父格为 B2 。

    image.png

    2)A2 单元格输入公式:

    INARRAY(B2,UNIQUEARRAY(B2[!0]))+"."+INARRAY(C2,UNIQUEARRAY(C2[!0]{B2=$B2}))

    image.png

    2.3 效果预览

    1)PC端

    保存报表,点击分页预览,多级序号效果如下图所示:

    image.png

    2)移动端

    image.png

    3. 模板下载

    已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\Advanced\Cacuate_Between_Cells\多级序号.cpt

    点击下载模板:多级序号.cpt

    4. 注意事项

    如果有第三列数据 (D2) 也要生成序号,则 A2 左父格为 C2 ,公式为:INARRAY(B2,UNIQUEARRAY(B2[!0]))+"."+INARRAY(C2,UNIQUEARRAY(C2[!0]{B2=$B2}))+"."+INARRAY(D2,UNIQUEARRAY(D2[!0]{B2=$B2&&C2=$C2}))

    如果有第四列数据 (E2) 也要生成序号,则 A2 左父格为 D2 ,公式为:INARRAY(B2,UNIQUEARRAY(B2[!0]))+"."+INARRAY(C2,UNIQUEARRAY(C2[!0]{B2=$B2}))+"."+INARRAY(D2,UNIQUEARRAY(D2[!0]{B2=$B2&&C2=$C2}))+"."+INARRAY(E2,UNIQUEARRAY(E2[!0]{B2=$B2&&C2=$C2&&D2=$D2}))

    如此类推。

    附件列表


    主题: 报表专题
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持