cxGrid合计忽略重复记录

【属性设置】
1.cxGrid1DBBandedTableView1.OptionsView.FooterMultiSummaries = True;   //如果为False时Footer就只能显示一行

2.双击cxGrid在弹出窗口的Summary页签, 加上要合计的Item并设好各个Item的Column、FormatKind属性。 如下图


【代码部份】
uses
  cxGridDBTableView;

  private
    lstCust: TStringList;         //存放不同的客户编号记录


procedure TfrmVS.FormCreate(Sender: TObject);
begin
  inherited;
  lstCust := TStringList.Create;  //创建lstCust对象
end;

procedure TfrmVS.FormClose(Sender: TObject; var Action: TCloseAction);
begin
  FreeAndNil(lstCust);    //释放lstCust对象 
  inherited;
end;

procedure TfrmVS.SmartDataSetMap1BeforeOpen(DataSet: TDataSet);
begin
  lstCust.Clear;                  //重新打开数据集前清空lstCust
  inherited;
  ...
end;

//cxGrid1DBBandedTableView1->DataController->Summary->FooterSummaryItems->OnSummary 事件
procedure TfrmVS.cxGrid1DBBandedTableView1DataControllerSummaryFooterSummaryItemsSummary(
  ASender: TcxDataSummaryItems; Arguments: TcxSummaryEventArguments;
  var OutArguments: TcxSummaryEventOutArguments);
var
  sCustNo: String;
begin
  //只对colaCustNo列的合计进行处理
  if TcxGridDBTableSummaryItem(Arguments.SummaryItem).Column = colaCustNo then
  begin
    sCustNo := vartostr(ASender.DataController.Values[Arguments.RecordIndex, colaCustNo.Index]);
    if lstCust.IndexOf(sCustNo) = -1 then
    begin
      lstCust.Add(sCustNo);   //记下之前未出现过的客户编号
    end;
  end;
end;

//合计Item的OnGetText 事件
procedure TfrmVS.cxGrid1DBBandedTableView1TSmartGridDBDataControllerTcxDataSummaryFooterSummaryItems2GetText(
  Sender: TcxDataSummaryItem; const AValue: Variant; AIsFooter: Boolean;
  var AText: string);
begin
  //lstCust.Count就是不同的客户数
  AText := IntToStr(lstCust.Count);
end;

【运行效果】

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值