如何在数据标签中将时间值格式化为HH:MM:SS

Jam*_*213 6 graph crystal-reports

所以我在水晶报告中有一个条形图.在此图表上,我有一个数据标签附加到每个图表,以秒为单位显示图表的值,如下所示: 在此输入图像描述 我想做的是将此数据标签格式化为时间格式.因此,对于图表中的每个条形,数据标签将以以下格式显示:

HH:MM:SS.

我能够使用以下公式获得时间格式:

local NumberVar Sec;
local NumberVar ss;
local NumberVar mm;
local NumberVar hh;
local StringVar SSS;
local StringVar MMM;

Sec := Sum ({GetAlarmSummaryDataSet2Response/GetAlarmSummaryDataSet2Result/Items/AlarmSummaryItem2.StopTime}, {GetAlarmSummaryDataSet2Response/GetAlarmSummaryDataSet2Result/Items/AlarmSummaryItem2.Section}) ;
hh := Int (Sec/3600);
mm :=Int ((Sec/60)- (60* Int(Sec/3600 )));
If mm<10 then MMM := "0" & ToText (mm,0);
If mm>9 Then MMM := ToText(mm,0) ;

ss :=Sec-(3600 * hh ) - (60 * mm ) ;
If ss<10 then SSS := "0" & ToText (ss,0);
If ss>9 Then SSS := ToText(ss,0) ;

ToText ( hh,0) & ":" & MMM & ":" & SSS
Run Code Online (Sandbox Code Playgroud)

但我不确定的是如何将这个公式实现到数据标签上.

非常感谢任何帮助或建议.

谢谢

pau*_*kow 1

您可以选择显示组名称,并且可以显示图表计算的汇总值并设置其格式,但无法提供自定义公式。使用 CR XI 中的图表库是不可能的。

我对这个问题的最终解决方法:

  1. 修改数值公式,消除聚合函数。(这是必要的,因为 Crystal 不允许在组名称字段中使用聚合函数 - 请参阅#2。)
  2. 对于组名称,请指定一个公式以及要在提升板中显示的文本。包括标签和格式化值,用 分隔Chr(13) & Chr(10)以将它们放在不同的行上。
  3. 配置提升板以显示标签,而不是值。

要将其应用于您的问题,您需要进行以下更改:

  1. 消除聚合函数。当然,我不知道使用您的设置是否可以实现这一点。也许如果您使用的是 DBMS,则可以在数据到达 Crystal 之前使用 SQL 命令或存储过程来计算总和。
  2. 将标签和值一起打印在立板或 X 轴上。

如果这对您的应用程序来说还不够好,您可以考虑CRChart,这是一个商业替代品,它试图解决 Crystal 图表库有时会造成严重的限制。(我认为它太贵了。)我认为@APPEND_DATATEXT宏可以让您在提升板上放置自定义值,但您仍然需要将摘要移动到服务器。