是否可以查询扩展对象的列表
本文关键字:对象 列表 扩展 查询 是否 | 更新日期: 2023-09-27 18:30:54
我想知道是否可以使用常规 LINQ 查询 ExpandoObject?原因是我有动态扩展对象,但我需要做一些查询才能进一步传递。
它具有一些始终保持的特性,例如 Id
,Notes
还有一些我无法控制的动态属性。
这是我的清单的样子
[
{
"Id": 1,
"FileId": 1,
"Notes": "",
"1": "12.02.1991"
},
{
"Id": 2,
"FileId": 2,
"Notes": "",
"1": "12.02.1991"
}
]
法典
如您所见,我有我的静态项,然后我确保每个项动态键都成为该项属性。在此示例中,1
是键,12.02.1991
是值
var generatedItems = new List<object>();
foreach (var item in items)
{
var modifiedItem = new List<KeyValuePair<string, object>>
{
new KeyValuePair<string, object>("Id", item.Id),
new KeyValuePair<string, object>("FileId", item.FileId),
new KeyValuePair<string, object>("Notes", item.Notes)
};
modifiedItem.AddRange(item.Fields.Select(field => new KeyValuePair<string, object>(field.Key, field.Value)));
generatedItems.Add(ConvertToExpandoObjects(modifiedItem)); // Here I construct object from key/value pairs
}
return generatedItems; // Is it possible to query this thing?
我认为这无关紧要,但这是我的 ConvertToExpandoObjects 功能。
public static dynamic ConvertToExpandoObjects(IEnumerable<KeyValuePair<string, object>> pairs)
{
IDictionary<string, object> result = new ExpandoObject();
foreach (var pair in pairs)
result.Add(pair.Key, pair.Value);
return result;
}
我试图简单地做一些类似generatedItems.Where(x => x.);
但显然它没有给我任何东西可以做,因为它不知道这些对象有Id
等。
那么是否可以查询它,如果是,那么如何查询?
您的建议是正确的,您将能够使用点表示法查询动态对象的集合。
var ids = generatedItems.Cast<dynamic>().Select(x => x.Id);
但是,请记住,这里没有类型安全,正如您所说,IntelliSense 没有用,因为您使用的是动态对象。
如果您的代码依赖于其中一个对象是否具有可选属性(例如,有些具有"Title",其他对象没有),那么它将需要更多的手动劳动。
if((generatedItems as IDictionary<String, object>).ContainsKey("Title")) {
}