簡體   English   中英

使用C#獲取xml的屬性和值

[英]getting attributes and values of xml using C#

我做了一個程序,從數據庫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 =“學生信息”

等等..

您可以通過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);

從XML到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;
    }
  }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM