反馈已提交

网络繁忙

您正在浏览的是 FineBI6.1 帮助文档,点击跳转至: FineBI5.1帮助文档

导出Excel报错

  • 文档创建者:doreen0813
  • 历史版本:15
  • 最近更新:April陶 于 2023-12-06
  • 1. java.lang.NullPointerException

    问题描述:

    仪表板组件导出 Excel 后,打开 Excel 报错:errorCode:500, errorMsg: java.lang.NullPointerException,如下图所示:

    1.png

    查看 FineBI 日志%FineBI%/logs/fanruan.log,对应的报错如下:

    java.lang.NullPointerException
    at sun.awt.FontConfiguration.getVersion(FontConfiguration.java:1264)
    at sun.awt.FontConfiguration.readFontConfigFile(FontConfiguration.java:219)
    at sun.awt.FontConfiguration.init(FontConfiguration.java:107)
    at sun.awt.X11FontManager.createFontConfiguration(X11FontManager.java:774)
    at sun.font.SunFontManager$2.run(SunFontManager.java:431)
    at java.security.AccessController.doPrivileged(Native Method)
    at sun.font.SunFontManager.<init>(SunFontManager.java:376)
    at sun.awt.FcFontManager.<init>(FcFontManager.java:35)
    at sun.awt.X11FontManager.<init>(X11FontManager.java:57)
    at sun.reflect.GeneratedConstructorAccessor654.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at java.lang.Class.newInstance(Class.java:442)
    at sun.font.FontManagerFactory$1.run(FontManagerFactory.java:83)
    at java.security.AccessController.doPrivileged(Native Method)
    at sun.font.FontManagerFactory.getInstance(FontManagerFactory.java:74)
    at java.awt.Font.getFont2D(Font.java:491)
    at java.awt.Font.canDisplayUpTo(Font.java:2060)
    at java.awt.font.TextLayout.singleFont(TextLayout.java:470)
    at java.awt.font.TextLayout.<init>(TextLayout.java:531)
    at com.fr.third.v2.org.apache.poi.ss.util.SheetUtil.getDefaultCharWidth(SheetUtil.java:254)

    原因分析:

    该报错是由于 Linux 系统没有相关 font 资源导致,需要为系统安装字体管理器。

    解决方案:

    在 Linux 中执行如下命令安装字体管理:

    yum install fontconfig

    如果使用 docker 制作基础镜像运行以下命令:

    RUN yum -y install fontconfig
    RUN fc-cache --forc

    2. java.lang.IllegalArgumentException:The workbook already contains a sheet of this name

    问题描述:

    导出 Excel,打开 Excel 报错如下:

    image.png

    原因分析:

     Excel中 sheet 命名有如下规则:

    1)sheet 名称不能多于31个(包含英文、汉字、| 、()等,但是不能包含: 、/、?、*、[]等 ),程序中使用 poi 工具来生成的时候,传进去大于 31 个长度的字符串时,会被自动截取,便会导致两个名字变为一样的,出现sheet同名异常

    2)sheet 名字不能为空,为空也会报错。

    解决方案:

    修改组件名称以及对应的长度,使其符合excel命名规则。

    3. Could not initialize class sun.awt.X11GraphicsEnvironment

    问题描述:

    Linux 环境下导出 Excel 失败,查看日志或按 F12 进入控制台,出现报错:Could not initialize class sun.awt.X11GraphicsEnvironment

    原因分析:

    在Linux下,仪表板导出 Excel 时,会用到 Java 的图片包来处理图片。而 Java 虚拟机在处理图片时需要本地的 x-server 支持,若是没有就会出现该报错。

    解决方案:

    • 直接安装的 FineBI

    在路径 %FineBI5.1%\bin 下找到finebi.vmoption文件,在文件内新增-Djava.awt.headless=true保存文件。如下图所示:

    image.png

    • 部署到 Tomcat 的 FineBI

    进入%Tomcat%/bin目录,找到并编辑配置文件catalina.sh,增加-Djava.awt.headless=true参数,详情请参见:导出 Excel 设置

    4. com.finebi.common.exception.execute.FineOutOfMaxRowException: out of row restriction: xxxxxxx

    问题描述:

    导出 Excel,打开 Excel 报错如下:

    原因分析:

    导出的 Excel 数据量超过数据量限制。

    解决方案:

    通过筛选等方式减少导出数据量。

    5. 数据量超过限制:Export Column Out Of Limit!

    问题描述:

    仪表板导出 Excel 时报错数据量超过限制:超过100列无法导出,请联系管理员,如下图所示:

    2.png

    原因分析:

    导出列数超过100列。

    解决方案:

    在工程配置库 finedb 的 fine_conf_entity 表中添加一个参数

    • id为:SystemOptimizationConfig.crossExportColumnLimit

    • value为:数值,不建议将数值修改很大。

    附件列表


    主题: 制作可视化组件
    已经是第一篇
    已经是最后一篇
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

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

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

    不再提示

    10s后关闭



    AI

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