基于Kevin Hazzard的帖子; http://blogs.captechconsulting.com/blog/kevin-hazzard/fluent-xml-parsing-using-cs-dynamic-type-part-1 我正在尝试使用逻辑.基本上应该做的是获取一段XML并将其转换为可以使用的对象.比如说我的xml是;
<someObject>
<Name>Timmy</Name>
</someObject>
Run Code Online (Sandbox Code Playgroud)
我希望能够做到;
dynamic obj = Converter(xmlText);
string name obj.Name;
Run Code Online (Sandbox Code Playgroud)
经过大量的谷歌搜索,我遇到了凯文的博客并发布了一个DynamicXml应该完成工作的对象,但是我无法让它工作(或者我没有正确使用它).我对.NET的Expando对象的理解是有限的,我没有代码样本去博客文章吧.我把凯文关于这个主题的两篇文章整理成一个单独的对象.
public class DynamicXml : DynamicObject, IEnumerable
{
private readonly List<XElement> _elements;
public DynamicXml(string text)
{
var doc = XDocument.Parse(text);
_elements = new List<XElement> { doc.Root };
}
protected DynamicXml(XElement element)
{
_elements = new List<XElement> { element };
}
protected DynamicXml(IEnumerable<XElement> elements)
{
_elements = new List<XElement>(elements);
}
public override bool TryGetMember(GetMemberBinder binder, out object result)
{
result = null;
// handle the Value and Count special cases
if (binder.Name == "Value")
{
result = _elements[0].Value;
}
else if (binder.Name == "Count")
{
result = _elements.Count;
}
else
{
// try to find a named attribute first
var attr = _elements[0].Attribute(XName.Get(binder.Name));
if (attr != null)
{
// if a named attribute was found, return that NON-dynamic object
result = attr;
}
else
{
// find the named descendants
var items = _elements.Descendants(
XName.Get(binder.Name));
if (items != null && items.Count() > 0)
{
// prepare a new dynamic object with the list of found descendants
result = new DynamicXml(items);
}
}
}
if (result == null)
{
// not found, create a new element here
_elements[0].AddFirst(new XElement(binder.Name));
result = new DynamicXml(_elements[0].Descendants().First());
}
return true;
}
public override bool TrySetMember(SetMemberBinder binder, object value)
{
if (binder.Name == "Value")
{
/* the Value property is the only one that may be modified. TryGetMember actually
creates new XML elements in this implementation */
_elements[0].Value = value.ToString();
return true;
}
return false;
}
public override bool TryGetIndex(GetIndexBinder binder, object[] indexes, out object result)
{
int ndx = (int)indexes[0];
result = new DynamicXml(_elements[ndx]);
return true;
}
public IEnumerator GetEnumerator()
{
foreach (var element in _elements)
yield return new DynamicXml(element);
}
}
Run Code Online (Sandbox Code Playgroud)
我的用法是;
dynamic payload = new DynamicXml(PayloadData);
Name = payload.Name; // error thrown here
Run Code Online (Sandbox Code Playgroud)
例外是;
Cannot implicitly convert type 'MyProject.Common.Exchange.DynamicXml' to 'string'
Run Code Online (Sandbox Code Playgroud)
当我检查对象时,它似乎是一个嵌套的系列DynamicXml- 从查看代码的内部结构似乎是正确的.所以我不知道我是如何实现价值的Name?根据博客它应该是payload.Name.思考?
您错过了一件非常重要的事情:您可以按名称调用节点,但必须取消引用它的值,因为getMember始终返回DynamicXml对象.
尝试:
payload.Name.Value
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1009 次 |
| 最近记录: |