我正在使用C#并从sqlite查询响应中创建列表.
List1[i].field = fieldname
我想使用存储在List1 [i] .field中的fieldname来访问List2中的项目,例如:
List2[ii].+List1[i].field+
我不知道这是否可能以这种方式在C#中对我来说相对较新,并且基本上脱离了我的PHP知识,这样的东西确实有效.
解决方法
对于这种类型的数据结构,通常使用字典(键/值对)来动态选择对象的属性.对于您的具体示例,这可以通过反射来完成,但它并不常用,因为其他结构使其更容易.
List2[ii].GetType().GetProperty(List1[i].field).GetValue(List2[ii],null);
反射通常不是最快的解决方案类型,如果可以避免,通常不会很好地进入并维护具有大量反射的代码.
或者,您可以使用Linq将List2从对象类型列表中转移到字典对象列表中,这样您就可以执行类似List2 [ii] [List1 [i] .field]的操作来完成相同的操作.
var listDictionaries = List2 .Select(l => new Dictionary<string,object>() { new { "Prop1",l.Prop1 },new { "Prop2",l.Prop2 },new { "Prop3",l.Prop3 },}).ToArray(); listDictionaries[ii][List1[i].field];
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。