DevExpress GridView 列自定义汇总CustomSummaryCalculate——时间点汇总计算

42 篇文章 15 订阅
14 篇文章 6 订阅

涛神联合Dxper.Net开发者论坛管理在腾讯课堂开启DevExpress基础和高级培训课程 详情可以加群QQ群:294560883

DevExpress 的GridView或BanedGridView提供了自定义汇总的功能,目的是解决一些特殊的统计计算;

要让实现自定义统计功能,

1、首先当然是设置GridView.OptionsView.ShowFooter=true;显示汇总统计行在GridView的底部;

2、设置要自定义汇总统计的列的SummaryItem>SummaryType属性为Custom,如下图

3、注册GridView的CustomSummaryCalculate事件

以上为准备工作,事件内具体的代码处理,这里我提供一个通用的方法给大家,代码说明见注释

        /// <summary>
        /// 自定义时间点汇总统计
        /// </summary>
        /// <param name="view">GridView视图</param>
        /// <param name="timeFieldNames">要自定义汇总的时间点列</param>
        public static void CustomTimeSummary(GridView view, params string[] timeFieldNames)
        {
            //强制初始化,如果列是动态通过数据源加载的,则绑定数据源后gridview想获取列的话,需要调用强制初始化的方法
            view.GridControl.ForceInitialize();
            //设置指定列的汇总统计会自定义汇总
            foreach(var field in timeFieldNames)
            {
                var col = view.Columns[field];
                if (col != null)
                {
                    col.SummaryItem.SummaryType = SummaryItemType.Custom;
                }
            }
            
            TimeSpan sum = new TimeSpan(0, 0, 0);
            view.CustomSummaryCalculate += (s, e) =>
            {
                if (e.IsTotalSummary && timeFieldNames.Contains((e.Item as GridSummaryItem).FieldName))
                {
                    GridSummaryItem item = e.Item as GridSummaryItem;
                    if (timeFieldNames.Contains(item.FieldName))
                    {
                        switch (e.SummaryProcess)
                        {
                            case CustomSummaryProcess.Start://开始计算
                                sum = new TimeSpan(0, 0, 0);
                                break;
                            case CustomSummaryProcess.Calculate://计算中
                                if (TimeSpan.TryParse(e.FieldValue?.ToString(), out TimeSpan result))
                                {
                                    sum += result;
                                }
                                else
                                {
                                    var strs = e.FieldValue?.ToString().Split(':');
                                    if (strs!=null&&strs.Length == 2)
                                    {
                                        int h = Convert.ToInt32(strs[0]);
                                        int m = Convert.ToInt32(strs[1]);
                                        if (m >= 60)
                                        {
                                            h += 1;
                                            m = m - 60;
                                        }
                                        if (h > 24)
                                        {
                                            var day = h / 24;

                                            var time = new TimeSpan(h/24, h-24*day, m, 0);
                                            sum += time;
                                        }
                                        else
                                        {
                                            var time = new TimeSpan( h, m, 0);
                                            sum += time;
                                        }
                                    }
                                }
                                break;
                            case CustomSummaryProcess.Finalize://计算完毕设置值
                                e.TotalValue = $"{sum.Days * 24 + sum.Hours}小时{sum.Minutes}分";
                                break;
                        }
                    }
                }
            };
            //重新刷新数据源,这样才能触发CustomSummaryCalculate事件
            view.RefreshData();
        }

调用示例:

 private void Form2_Load(object sender, EventArgs e)
        {
            gridView1.Columns.Clear();
            DataTable dt = new DataTable();
            dt.Columns.Add("id");
            dt.Columns.Add("time");
            dt.Columns.Add("time2");
            dt.Rows.Add(1, "08:31", "08:31");
            dt.Rows.Add(2, "10:60", "01:32");
            dt.Rows.Add(3, "90:31", "08:32");
            gridControl1.DataSource = dt;

            CustomTimeSummary(gridView1, "time", "time2");
           
        }

结果图:

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
DevExpress GridViewDevExpress控件库中的一个组件,用于显示和编辑数据。它是GridControl的一个子类,负责显示数据并提供各种功能和选项来自定义显示和交互。\[3\] 在GridView中,可以使用OptionsDetail属性来控制是否显示从表。默认情况下,OptionsDetail.EnableMasterViewMode属性设置为false,表示不显示从表。如果需要自定义从表的显示,可以使用MasterRowExpanded事件来实现。在该事件中,可以获取所击行的从表对象,并通过设置子表的Columns属性来隐藏或显示。\[1\] 另外,GridView还提供了一些自定义绘制的事件,例如CustomDrawRowIndicator事件,可以用来显示序号或行号。在该事件中,可以通过设置RowIndicatorCustomDrawEventArgs的DisplayText属性来显示行号。\[2\] #### 引用[.reference_title] - *1* [DevExpress gridview](https://blog.csdn.net/weixin_45611944/article/details/119360503)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [C# devExpressGridView用法合集](https://blog.csdn.net/FFFAN_KIKI/article/details/123326413)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [DevExpress表格控件(GridView、GridControl)使用小结](https://blog.csdn.net/qq_23944441/article/details/81563320)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值