Список уникальных значений в столбце в XtraGrid - PullRequest
4 голосов
/ 08 декабря 2011

enter image description here

Есть ли способ получить список уникальных значений в любом столбце в XtraGrid. Когда я нажимаю на заголовок столбца для фильтрации, он показывает список (см. Прикрепленное изображение '}').

Существует ли какой-либо объект XtraGrid или объект Column, с помощью которого я могу получить это в виде массива или списка?

1 Ответ

3 голосов
/ 09 декабря 2011

Как насчет того, чтобы реализовать его как метод расширения в GridView следующим образом

using System;
using System.Linq;
using System.Collections.Generic;
using DevExpress.XtraGrid.Views.Grid;

namespace Extensions
{
    public static class XtraGridExtensions
    {
        public static IEnumerable<string> GetColumnsDistinctDisplayText(this GridView gv, string columnName)
        {
            if (gv == null)
            {
                throw new NullReferenceException("GridView is null");
            }
            if (gv.RowCount == 0)
            {
                return Enumerable.Empty<string>();
            }
            return (from int row in Enumerable.Range(0, gv.RowCount - 1)
                    select gv.GetRowCellDisplayText(row, columnName)).Distinct().OrderBy(s => s);
        }
    }
}

, и всякий раз, когда вы захотите его использовать, используйте его следующим образом

using Extensions;

...

string msg = string.Empty;
foreach (var item in gridView1.GetColumnsDistinctDisplayText("columnName"))
{
    msg += item + "\n";
}
MessageBox.Show(msg);
...