91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

能否舉例c#中group的應用場景

c#
小樊
82
2024-09-20 08:02:20
欄目: 編程語言

在C#中,GroupBy是一個非常強大的LINQ(Language Integrated Query)方法,它允許你根據某個或某些屬性將集合中的元素進行分組。以下是一些GroupBy在C#中的常見應用場景:

  1. 按類型分組: 假設你有一個對象列表,每個對象都有一個類型屬性,你可以使用GroupBy來按這個類型屬性對這些對象進行分組。

    var people = new List<Person>
    {
        new Person { Name = "Alice", Age = 25, Type = "Student" },
        new Person { Name = "Bob", Age = 30, Type = "Employee" },
        new Person { Name = "Charlie", Age = 25, Type = "Student" },
        new Person { Name = "David", Age = 30, Type = "Employee" }
    };
    
    var groupedPeople = people.GroupBy(p => p.Type);
    
    foreach (var group in groupedPeople)
    {
        Console.WriteLine($"Group: {group.Key}");
        foreach (var person in group)
        {
            Console.WriteLine($"Name: {person.Name}, Age: {person.Age}");
        }
    }
    
  2. 按日期分組: 如果你有一個包含多個日期的對象列表,你可以使用GroupBy來按日期對這些對象進行分組。

    var events = new List<Event>
    {
        new Event { Date = new DateTime(2023, 1, 1), Name = "New Year's Day" },
        new Event { Date = new DateTime(2023, 1, 10), Name = "Rainy Day" },
        new Event { Date = new DateTime(2023, 2, 14), Name = "Valentine's Day" },
        new Event { Date = new DateTime(2023, 2, 14), Name = "Rainy Day" }
    };
    
    var groupedEvents = events.GroupBy(e => e.Date.Date);
    
    foreach (var group in groupedEvents)
    {
        Console.WriteLine($"Date: {group.Key}");
        foreach (var @event in group)
        {
            Console.WriteLine($"Name: {@event.Name}");
        }
    }
    
  3. 按地區分組: 如果你有一個包含多個銷售記錄的對象列表,每個記錄都有一個地區屬性,你可以使用GroupBy來按地區對這些記錄進行分組,并計算每個地區的總銷售額。

    var sales = new List<Sale>
    {
        new Sale { Region = "North", Amount = 1000 },
        new Sale { Region = "South", Amount = 1500 },
        new Sale { Region = "East", Amount = 750 },
        new Sale { Region = "West", Amount = 1250 },
        new Sale { Region = "South", Amount = 500 }
    };
    
    var groupedSales = sales.GroupBy(s => s.Region).ToDictionary(g => g.Key, g => g.Sum(s => s.Amount));
    
    foreach (var region in groupedSales.Keys)
    {
        Console.WriteLine($"Region: {region}, Total Sales: {groupedSales[region]}");
    }
    
  4. 按字符串的首字母分組: 你可以按字符串的首字母對字符串數組進行分組,這在創建字典或進行其他需要分組的操作時非常有用。

    var words = new string[] { "Apple", "Banana", "Cherry", "Date", "Elderberry" };
    
    var groupedWords = words.GroupBy(w => w[0]);
    
    foreach (var group in groupedWords)
    {
        Console.WriteLine($"First Letter: {group.Key}");
        foreach (var word in group)
        {
            Console.WriteLine(word);
        }
    }
    

這些示例展示了GroupBy在C#中的多樣性和實用性。你可以根據你的具體需求調整分組依據和后續操作。

0
峨山| 通化市| 龙南县| 高安市| 出国| 徐水县| 综艺| 清涧县| 双柏县| 乐昌市| 海阳市| 莒南县| 徐水县| 蓝山县| 同仁县| 华容县| 沙雅县| 福安市| 成都市| 迭部县| 滨海县| 香格里拉县| 垣曲县| 福建省| 屏山县| 博罗县| 名山县| 孟州市| 海丰县| 潮州市| 兴山县| 同江市| 寿阳县| 千阳县| 瓮安县| 吉首市| 华蓥市| 虹口区| 尚义县| 泸溪县| 个旧市|