Masalah:
Anda mempunyai senarai objek dengan sifat yang mengandungi nombor invois dalam format rentetan tertentu, cth., 200906/1. Pengisihan lalai Linq OrderBy dalam C# menghasilkan susunan pengisihan yang tidak diingini, seperti 200906/1, 200906/10, 200906/11.
Penyelesaian:
Kepada melaksanakan perintah pengisihan tersuai anda sendiri, anda boleh menentukan satu IComparer
public class MyComparer : IComparer<Object> { public int Compare(Object stringA, Object stringB) { string[] valueA = stringA.ToString().Split('/'); string[] valueB = stringB.ToString().Split('/'); if (valueA.Length != 2 || valueB.Length != 2) { return stringA.ToString().CompareTo(stringB.ToString()); } // Parse numbers for comparison int numA = int.Parse(valueA[0]); int numB = int.Parse(valueB[0]); if (numA == numB) { return int.Parse(valueA[1]).CompareTo(int.Parse(valueB[1])); } else { return numA.CompareTo(numB); } } }
Dalam kod asal anda, anda cuba menggunakan MyComparer anda dalam Linq OrderBy seperti berikut:
items = items.OrderByDescending( x => property.GetValue(x), comparer).ToList();
Pendekatan ini tidak betul. Sintaks yang betul untuk menggunakan pembanding anda ialah:
items = items.OrderBy(x => property.GetValue(x), comparer).ToList();
Perhatikan bahawa kaedah OrderBy digunakan dan bukannya OrderByDescending jika anda ingin mengisih dalam tertib menaik.
Akhir sekali, jangan lupa untuk tetapkan item yang diisih kembali ke sumber data anda untuk mencerminkan perubahan dalam UI anda:
this.Items = items;
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan IComparer Tersuai untuk Menyusun Objek dengan Betul dalam LINQ OrderBy?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!