繁体   English   中英

有没有更好的方法来组织这些数据而不是使用字符串数组?

[英]Is there a better way to organize this data rather than using string arrays?

我有两个循环从两个XML源提取数据:

循环1:

foreach (XmlNode nodes in node.ChildNodes)
            {
                if (nodes.Name == "DEFAULT")
                    defaults[count] = nodes.InnerText;
                if (nodes.Name == "TYPE"
                    types[count] = nodes.InnerText;
                if (nodes.Name == "COL_NAM"
                    names[count] = nodes.InnerText;

            }
            count++;

循环2:

foreach (XmlNode nodes in root.ChildNodes)
        {
            vals[i] = nodes.InnerText;
            cols[i] = nodes.Name;
            i++;
        }

不知何故,我想将这些数据组织成一个终极对象。 该对象需要有4个部分:名称,类型,值和默认值。 本质上,我想将Loop1中的所有内容组合在一起,然后将Loop2中的所有内容组合在一起,然后将两个对象组合成一个对象,该对象与Loop1中的名称和来自Loop2的cols匹配。 理想情况下,Loop2中的节点数量可能小于Loop1的节点数量。 但是,如果那是不可能的,我可以解决它。

为了更好地了解最终对象:

object everything = {{names}, {types}, {values}, {defaults}};

名称将来自BOTH循环,并将成为对象的“键”。 类型和默认值将来自Loop1,值将来自Loop2。 串联将使用Name / Col匹配。

PS:我试图使用2D String数组来做这件事,但在尝试将两个匹配的cols和names字段组合时遇到了麻烦。

您可以使用Dictionary类并使用Name作为对象的键。

例如:

public class MyObj{
  public string Name{get;set;};
  public string Type{get;set;};
  public string Value{get;set;};
  public string Default{get;set;};
}

并修改你的循环使用它:

var allObjs = new Dictionary<string, MyObj>();   


foreach (XmlNode nodes in node.ChildNodes)
{
  var obj = new MyObj();
    if (nodes.Name == "DEFAULT")
      obj.Default = nodes.InnerText;
    ...
    allObjs.Add(obj.Name, obj);
}

然后在第二个循环中使用键检索现有对象以更新值。 像这样的东西:

foreach (XmlNode nodes in root.ChildNodes)
{
  var myObj = allObs[nodes.Name];
  myObj.Value = nodes.InnerText;
}

好吧,您可以使用XPath来选择您的值。

public class Ultimate
{
    public Ultimate(XmlNode node)
    {
       XmlNode child = node.SelectSingleObject("./COL_NAM");
       if (child == null) throw new InvalidArgument("COL_NAM not found");
       Name = child.InnerText;

       XmlNode child = node.SelectSingleObject("./TYPE");
       if (child == null) throw new InvalidArgument("TYPE not found");
       Type = child.InnerText;

       XmlNode child = node.SelectSingleObject("./DEFAULT");
       if (child == null) throw new InvalidArgument("DEFAULT not found");
       Default = child.InnerText;

       XmlNode child = node.SelectSingleObject("./COL_NAM");
       if (child == null) throw new InvalidArgument("COL_NAM not found");
       Name = child.InnerText;

    }
    public string Name;
    public string Type;
    public string Value;
    public string Default;
}

//读取对象将是这样的:

Dictionary<string, Ultimate> ultimateCollection = new Dictionary<string, Ultimate>();
foreach(XmlNode node in xmlDocument1.SelectNodes("/DATA1"))
{
    Ultimate ultimate = new Ultimate(node);
    ultimateCollection.Add(ultimate.Name, ultimate);
}

foreach(XmlNode node in root.ChildNodes)
{
    Ultimate ultimate;
    if (ultimateCollection.TryGetValue(node.Name, out ultimate))
        ultimate.Values = node.InnerText;
}

我希望这能帮助你完成任务。

从你的描述听起来我会使用XElement \\ LINQ。 http://codingsense.wordpress.com/2008/09/23/join-xml-using-linq/

..和/或..

将xml序列化/反序列化为C#对象http://www.java2s.com/Code/CSharp/XML/XmlSerializationHelper.htm

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM