我做了一个程序,我从我的数据库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 =“学生信息”
依旧......
答案 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;
}
}