所以我遇到了一些程序,它们使用数据库中的数据构建特定的XML。
现在,我想创建应用程序,只需将其与值一起挂在结构化类上,它将能够动态读取它。
我对这堂课的想法是这样的
public class Order
{
public string PO_NO { get; set; }
................
public List<OrderDetails> OrderDetails = new List<OrderDetails>();
}
和XML如下所示
<ORDER>
<PO_NO>18060001</PO_NO>
....
-<ORDER_DETAILS>
-<ORDER_DETAIL>
</ORDER_DETAIL>
-<ORDER_DETAIL>
</ORDER_DETAIL>
...
</ORDER_DETAILS>
-</ORDER>
我希望本文涵盖了结构和思想。
到目前为止,我一直在努力地动态阅读课程。
我最后一次询问的最接近的尝试是:
foreach (var refer in DatabaseData.getRefs()) //just gets reference numbers for me, for further reading
{
//THIS one returns the filled class. Eg. the Order class explained higher.
var MyClass = DatabaseData.read(refer);
var fiel = DatabaseData.read(refer).GetType().GetFields(BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Public);
foreach (var field in fiel)
{
var fieldName = field.Name.Replace('<', ' ').Replace('>', ' ').Replace("__", null).Replace("kBackingField", null);
if (field.FieldType.ToString().Contains("List"))
Debug.WriteLine("its a list");
else
Debug.WriteLine((string)DatabaseData.read(refer).GetType().GetField(fieldName).GetValue(Activator.CreateInstance(DatabaseData.read(refer).GetType())));
}
}
这是困扰我的部分。我已经尝试了在论坛上发现的许多变体,但仍然可以。对象引用未设置为对象实例。
(string)DatabaseData.read(refer).GetType().GetField(fieldName).GetValue(Activator.CreateInstance(DatabaseData.read(refer).GetType()))
有什么想法吗?或以正确的方式指出我。
谢谢。
答案 0 :(得分:2)
这里不需要您自己做任何事;只需使用XmlSerializer
。
您可能需要添加一些属性以获取所需的XML:
[XmlRoot("ORDER")]
public class Order
{
[XmlElement("PO_NO")] // note this one is implicit and not strictly needed
public string PO_NO { get; set; }
[XmlArray("ORDER_DETAILS")]
[XmlArrayItem("ORDER_DETAIL")]
public List<OrderDetails> OrderDetails {get;} = new List<OrderDetails>();
}
然后:
var serializer = new XmlSerializer(typeof(Order));
完成此操作并不重要,但是在这种情况下,还需要使用Roslyn支持的字段信息-只需查看GetProperties()
和GetFields()
,然后使用{{1} },而不是PropertyInfo.SetValue(...)
;含义:使用属性,而不是背景字段。