使用C#获取xml的属性和值

时间:2010-11-21 10:07:35

标签: c# xml

我做了一个程序,我从我的数据库SQL 2005中检索xml代码,现在我想在Windows窗体应用程序中显示所有的属性以及它们的值。是否有任何功能支持??怎么样?

<Permission>
    <CP name="Student">
        <tab name="studentinfo">
        </tab>
        <tab name="notes">
            <groupbox name="ss">
            <field type="textArea" x="xxx" />
            </groupbox>
        </tab>
    </CP>
    <CP name="Teacher">
    </CP>
    <CP name="doctor">
    </CP>
</Permission>

输出: NAME = “学生” name =“学生信息”

依旧......

2 个答案:

答案 0 :(得分:1)

您可以通过XML到Linq执行此操作:

        XDocument xmlDoc = XDocument.Load("a.xml");
        var nodeAttrs = xmlDoc.Descendants().Select(x => x.Attributes());
        foreach (var attrs in nodeAttrs)
        {
            foreach (var attr in attrs)
                Console.WriteLine("Name: {0}, Value :{1}", attr.Name ,attr.Value);
        }

输出如下所示:

Name: name, Value :Student
Name: name, Value :studentinfo
Name: name, Value :notes
Name: name, Value :ss
Name: type, Value :textArea
Name: x, Value :xxx
Name: name, Value :Teacher
Name: name, Value :doctor

编辑如果您有一个表示您的XML的字符串,则可以

    var xmlString = "<Permission> <CP name=\"Student\"> <tab name=\"studentinfo\"></tab><tab name=\"notes\"><groupbox name=\"ss\"><field type=\"textArea\" x=\"xxx\" /></groupbox></tab></CP><CP name=\"Teacher\"></CP><CP name=\"doctor\"></CP></Permission>";
    byte[] byteArray = Encoding.ASCII.GetBytes( xmlString );
    MemoryStream stream = new MemoryStream( byteArray);

然后

var xmlDoc = XDocument.Load(stream);

答案 1 :(得分:0)

XML to LINQ库使这非常简单

  using (XmlTextReader reader = new XmlTextReader("C:/whatever.xml"))
  {
    reader.Read();
    XElement permission = (XElement)XElement.ReadFrom(reader);
    string name = permission.Element("CP").Attribute("name").Value;
    foreach (var tab in permission.Element("CP").Elements("tab"))
    {
      string tabName = tab.Attribute("name").Value;
    }
  }