Использование Visual C# для сортировки элемента управления ListView по столбцу
В этой статье содержатся сведения о том, как сортировать элемент управления ListView с помощью столбца в Visual C#, а также приведен пример кода для объяснения методов.
Исходная версия продукта: Visual C#
Исходный номер базы знаний: 319401
Сводка
При работе с элементом управления ListView может потребоваться отсортировать его содержимое по определенному столбцу. Пример такой функциональности можно найти в программе Windows Обозреватель при просмотре содержимого папки на жестком диске. В представлении Сведений windows Обозреватель отображает сведения о файлах в этой папке. Например, вы увидите имя файла, размер файла, тип файла и дату изменения файла. Щелкнув один из заголовков столбцов, список сортируется по возрастанию на основе этого столбца. При повторном щелчке того же заголовка столбца столбец сортируется в порядке убывания.
В примере в этой статье определяется класс, наследующий от IComparer
интерфейса . Кроме того, в этом примере используется Compare
метод CaseInsenstiveComparer
класса для фактического сравнения элементов.
Примечание.
- Этот метод сравнения не учитывает регистр.
- Все столбцы в этом примере сортируются по тексту .
Если вы хотите выполнить сортировку по-другому (например, числовое), можно заменить следующую строку кода любым подходом к сортировке, который вы хотите использовать:
ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text,listviewY.SubItems[ColumnToSort].Text);
Действия по созданию примера проекта
Создайте новый проект приложения Visual C# для Windows. Форма Form1 создается по умолчанию.
Добавьте элемент управления ListView в Form1. Размер формы, чтобы быть несколько дюймов в ширину на несколько дюймов в высоту.
Вставьте следующий код в класс для формы:
private ListViewColumnSorter lvwColumnSorter;
Вставьте следующий код в конструктор формы после вызова
InitializeComponent
метода :// Create an instance of a ListView column sorter and assign it // to the ListView control. lvwColumnSorter = new ListViewColumnSorter(); this.listView1.ListViewItemSorter = lvwColumnSorter;
Вставьте следующий код в
Load
событие для формы:ColumnHeader columnheader;// Used for creating column headers. ListViewItem listviewitem;// Used for creating listview items. // Ensure that the view is set to show details. listView1.View = View.Details; // Create some listview items consisting of first and last names. listviewitem = new ListViewItem("John"); listviewitem.SubItems.Add("Smith"); this.listView1.Items.Add(listviewitem); listviewitem = new ListViewItem("Bob"); listviewitem.SubItems.Add("Taylor"); this.listView1.Items.Add(listviewitem); listviewitem = new ListViewItem("Kim"); listviewitem.SubItems.Add("Zimmerman"); this.listView1.Items.Add(listviewitem); listviewitem = new ListViewItem("Olivia"); listviewitem.SubItems.Add("Johnson"); this.listView1.Items.Add(listviewitem); // Create some column headers for the data. columnheader = new ColumnHeader(); columnheader.Text = "First Name"; this.listView1.Columns.Add(columnheader); columnheader = new ColumnHeader(); columnheader.Text = "Last Name"; this.listView1.Columns.Add(columnheader); // Loop through and size each column header to fit the column header text. foreach (ColumnHeader ch in this.listView1.Columns) { ch.Width = -2; }
Примечание.
Код следует изменить в Visual Studio. При создании проекта Windows Forms Visual C# добавляет в проект одну форму по умолчанию. Эта форма называется Form1. Два файла, которые представляют форму, называются Form1.cs и Form1.designer.cs. Вы пишете код в Form1.cs. В файле Designer.cs Windows Forms Designer записывается код, который реализует все действия, выполняемые путем добавления элементов управления. Дополнительные сведения об Windows Forms Designer в Visual C# см. в статье Создание проекта (Visual C#).
Вставьте следующий код в
ColumnClick
событие для элемента управления ListView:// Determine if clicked column is already the column that is being sorted. if (e.Column == lvwColumnSorter.SortColumn) { // Reverse the current sort direction for this column. if (lvwColumnSorter.Order == SortOrder.Ascending) { lvwColumnSorter.Order = SortOrder.Descending; } else { lvwColumnSorter.Order = SortOrder.Ascending; } } else { // Set the column number that is to be sorted; default to ascending. lvwColumnSorter.SortColumn = e.Column; lvwColumnSorter.Order = SortOrder.Ascending; } // Perform the sort with these new sort options. this.listView1.Sort();
В меню Проект щелкните Добавить класс , чтобы добавить новый класс в проект.
Замените весь код по умолчанию в новом классе следующим кодом:
using System.Collections; using System.Windows.Forms; /// <summary> /// This class is an implementation of the 'IComparer' interface. /// </summary> public class ListViewColumnSorter : IComparer { /// <summary> /// Specifies the column to be sorted /// </summary> private int ColumnToSort; /// <summary> /// Specifies the order in which to sort (i.e. 'Ascending'). /// </summary> private SortOrder OrderOfSort; /// <summary> /// Case insensitive comparer object /// </summary> private CaseInsensitiveComparer ObjectCompare; /// <summary> /// Class constructor. Initializes various elements /// </summary> public ListViewColumnSorter() { // Initialize the column to '0' ColumnToSort = 0; // Initialize the sort order to 'none' OrderOfSort = SortOrder.None; // Initialize the CaseInsensitiveComparer object ObjectCompare = new CaseInsensitiveComparer(); } /// <summary> /// This method is inherited from the IComparer interface. It compares the two objects passed using a case insensitive comparison. /// </summary> /// <param name="x">First object to be compared</param> /// <param name="y">Second object to be compared</param> /// <returns>The result of the comparison. "0" if equal, negative if 'x' is less than 'y' and positive if 'x' is greater than 'y'</returns> public int Compare(object x, object y) { int compareResult; ListViewItem listviewX, listviewY; // Cast the objects to be compared to ListViewItem objects listviewX = (ListViewItem)x; listviewY = (ListViewItem)y; // Compare the two items compareResult = ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text,listviewY.SubItems[ColumnToSort].Text); // Calculate correct return value based on object comparison if (OrderOfSort == SortOrder.Ascending) { // Ascending sort is selected, return normal result of compare operation return compareResult; } else if (OrderOfSort == SortOrder.Descending) { // Descending sort is selected, return negative result of compare operation return (-compareResult); } else { // Return '0' to indicate they are equal return 0; } } /// <summary> /// Gets or sets the number of the column to which to apply the sorting operation (Defaults to '0'). /// </summary> public int SortColumn { set { ColumnToSort = value; } get { return ColumnToSort; } } /// <summary> /// Gets or sets the order of sorting to apply (for example, 'Ascending' or 'Descending'). /// </summary> public SortOrder Order { set { OrderOfSort = value; } get { return OrderOfSort; } } }
Сохраните, выполните сборку и запустите пример проекта.
Щелкните различные заголовки столбцов в элементе управления ListView. Щелкнув заголовок, содержимое элемента управления ListView сортируется по возрастанию в зависимости от выбранного столбца. При повторном щелчке того же заголовка столбца этот столбец отсортируется в порядке убывания.
Обратная связь
https://aka.ms/ContentUserFeedback.
Ожидается в ближайшее время: в течение 2024 года мы постепенно откажемся от GitHub Issues как механизма обратной связи для контента и заменим его новой системой обратной связи. Дополнительные сведения см. в разделеОтправить и просмотреть отзыв по