我試圖寫它使用反射,以獲取屬性並將其值設置在遍歷的XElement的方法:導入XML到對象遞歸
可以說我有這樣一類僅提供我的XML值要解析:
class XMLController
{
public string XML
{
get{
return @"<FieldGroup name='People' count='20'>
<Fields>
<Field Name='Jon' LastName='McFly'/>
<Field Name='Michael' LastName='Jackson'/>
</Fields>
</FieldGroup>";
}
}
}
這是我的對象怎麼看起來像:
class FieldGroup
{
public string Name {get;set;}
public string Count {get;set;}
public IEnumerable<Field> Fields {get;set;}
}
class Field
{
public string Name {get;set;}
public string LastName {get;set;}
}
映射器方法遍歷XElement
和由於節點南es與匹配的對象的名稱我認爲這有助於多一點,但我還沒有拿出一些真正有用的東西。我不想傳遞這個類型,但是,該方法幾乎可以處理傳入的所有XML格式相同的XML。
它只知道XML節點和屬性是匹配的名稱。
這是我做了什麼,但並沒有真正的工作:
class XMLObjectMapper
{
public T Map<T>(XElement element) where T: class, new()
{
T entity = (T) Activator.CreateInstance(typeof(T));
if(element.HasAttributes)
{
MapXMLAttributesToObject<T>(element,entity);
}
if(element.HasElements)
{
foreach (var childElement in element.Elements())
{
//if the child element has child elements as well, we know this is a collection.
if(childElement.HasElements)
{
var property = GetProperty<T>(childElement.Name.LocalName);
property.SetValue(entity,new List<property.PropertyType>());
Map<T>(childElement);
}
else
{
var property = GetProperty<T>(childElement.Name.LocalName);
var type = Activator.CreateInstance(property.PropertyType);
type.Dump();
}
}
}
return entity;
}
private void MapXMLAttributesToObject<T>(XElement element, T entity)
{
foreach(XAttribute attribute in element.Attributes())
{
var property = GetProperty<T>(attribute.Name.LocalName);
property.SetValue(entity,attribute.Value);
}
}
private PropertyInfo GetProperty<T>(string propertyName)
{
return typeof(T).GetProperty(propertyName,BindingFlags.IgnoreCase | BindingFlags.Public | BindingFlags.Instance);
}
}
「XmlSerializer」有問題嗎? – 2013-03-19 04:06:03
不幸的是,我不需要靈活性。 – Tarik 2013-03-19 04:17:55