从通用列表中删除属性/列

由于某种原因,我无法更改查询,因此我必须在C#中执行此操作。

我上课了:

public class myClass { int id { get; set; } string name { get; set; } DateTime sDate { get; set; } bool status { get; set; } } 

我得到的数据是在这个列表中获取的。 现在我想要的是从具有null值的列表中删除这些属性。 我可能听起来很疯狂,但你读得对。 我想过只创建一个只包含所选属性的列表,但上述任何属性都可以为null 。 所以我必须设计一种机制来基于此过滤我的列表。

为了更清楚,请考虑以下示例。

 List lstClass = some data source. 

获取数据后,通用列表(lstClass)看起来像这样。考虑表中的结果集:

 Id Name Sdate status 1 a null null 2 b null null 3 c null false 

我可以在删除属性sdate之后如何使我的列表看起来像这样。 所以我想要创建的新列表应该只有三个属性。

 Id Name status 1 a null 2 b null 3 c false 

有任何想法吗? 我可以使用Linq吗?

PS:这与演示无关。 我没有网格,我无法隐藏不是我想要的列。

假设您有myClass实例的通用列表,则可以创建仅包含所需属性的匿名类型:

 List list = ...; var reducedList = list.Select(e => new {e.id, e.name, e.status}).ToList(); // note: call to ToList() is optional foreach (var item in reducedList) { Console.WriteLine(item.id + " " + item.name + " " + item.status); //note: item does not have a property "sDate" } 

我不确定你应该在数据中解决你的问题,而是一个演示问题。 你想在哪个控件中显示它? 假设您使用AutoGenerateColumns = True在DataGrid中显示它,然后您可以1)为每个列/属性循环列/属性2)查看所有行的所有属性值是否为null,如果是,则将列的可见性设置为Collapsed。 如果您自己生成列,则更简单:只有当内容对于所有行都不为null时才添加列。
如果您的数据库内容是动态的,您可能希望将每行的可见性绑定到一个属性,该属性将表明所有行都为null或不为该属性。 根据您希望代码的通用程度,代码可能会有很大不同,如果您想要通用解决方案,使用Reflection来检索/获取/设置属性可能会有所帮助。