You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					41 lines
				
				1.3 KiB
			
		
		
			
		
	
	
					41 lines
				
				1.3 KiB
			| 
											6 months ago
										 | using SqlSugar;
 | ||
|  | using System;
 | ||
|  | using System.Collections;
 | ||
|  | using System.Collections.Generic;
 | ||
|  | using System.Linq;
 | ||
|  | using System.Security.Policy;
 | ||
|  | using System.Text;
 | ||
|  | 
 | ||
|  | namespace ReZero.SuperAPI.Items
 | ||
|  | {
 | ||
|  |     internal class Group: IResultService
 | ||
|  |     {
 | ||
|  |         public object GetResult(object data, ResultModel model)
 | ||
|  |         { 
 | ||
|  |             // 检查data是否是可枚举的集合
 | ||
|  |             if (data is IEnumerable enumerableData)
 | ||
|  |             {  
 | ||
|  |                 // 使用LINQ的GroupBy方法根据groupName进行分组
 | ||
|  |                 var groupedData = GroupDataByGroupName(enumerableData,model?.GroupName!);
 | ||
|  |                 return groupedData;
 | ||
|  |             }
 | ||
|  |             else
 | ||
|  |             {
 | ||
|  | 
 | ||
|  |                 // 如果data不是可枚举的集合,可以根据实际情况处理,比如抛出异常或返回原始data
 | ||
|  |                 return data;
 | ||
|  |             }
 | ||
|  |         }
 | ||
|  | 
 | ||
|  |         private object GroupDataByGroupName(IEnumerable data, string groupName)
 | ||
|  |         {
 | ||
|  |             // 这里假设data中的元素有一个名为GroupName的属性,你可能需要根据实际情况调整
 | ||
|  |             var groupedData = data.Cast<object>()
 | ||
|  |                 .GroupBy(item => item.GetType().GetProperty(groupName)?.GetValue(item)?.ToString())
 | ||
|  |                    .Select(it=>new {it.Key,Value=it.ToList() }).ToList(); ;
 | ||
|  |              
 | ||
|  |             return groupedData!;
 | ||
|  |         }
 | ||
|  |     } 
 | ||
|  | }
 |