嘿,我有两个xml文件和以下代码:
DataTable table = new DataTable();
List<string> headingNames = new List<string>();
List<string> valueNames = new List<string>();
//first xml file
XDocument config = XDocument.Load(configFile);
Dictionary<string, string> dict = config.Descendants("Columns").FirstOrDefault().Elements()
.GroupBy(x => (string)x.Attribute("XPath"), y => (string)y.Attribute("Name"))
.ToDictionary(x => x.Key, y => y.FirstOrDefault());
//second xml file
XDocument data = XDocument.Load(dataFile);
List<XElement> positions = data.Descendants("Position").ToList();
但我必须将其更改为XMLDocument代码。
这是第一个XML:
<?xml version="1.0" encoding="utf-8"?>
<ROOT>
<Columns BaseXPath="//Orders/Position/">
<Colum XPath="@PositionSK" Name="Position"/>
<Colum XPath="@PosGroup" Name="Gruppen-Nr"/>
<Colum XPath="@PosNumber" Name="PositionsNr"/>
<Colum XPath="@PositionCommercialTypeSK" Name="Status"/>
<Colum XPath="@BundlePositionSK" Name="BundlePositionSK"/>
<Colum XPath="@MainPositionSK" Name="MainPositionSK"/>
<Colum XPath="@SalesAgentPrice" Name="Preis"/>
<Colum XPath="@Catchword" Name="Suchwort"/>
<Colum XPath="@ContentComponentCommSK" Name="IKO"/>
<Colum XPath="@PositionTypeSK" Name="PositionsTyp"/>
<Colum XPath="//Advertisement[@AdvertisementSK = PositionAdvertisementRelationship/@AdvertisementSK]/@AdvertisementSK" Name="AdvertisementSK"/>
<Colum XPath="//Advertisement[@AdvertisementSK = PositionAdvertisementRelationship/@AdvertisementSK]/@AdvertisementTypeSK" Name="Formatvorgabe"/>
</Columns>
</ROOT>
我希望所有的名字都带有@和&#34;名称&#34;:位置,Gruppen-Nr,......
所以在Dic(来自我的代码)中站着 {[@ PositionSK,Position]},{[@PosGroup,Gruppen-Nr]},...
那么如何使用XMLDocument获得相同的结果呢?
下一步我有:
foreach (XElement position in positions.Where(e => e.HasAttributes))
{
valueNames.Clear();
headingNames.Clear();
foreach (XAttribute attribute in position.Attributes().Where(a => dict.ContainsKey($"@{a.Name.LocalName}")))
{
string name = attribute.Name.LocalName;
string xName = dict["@" + name];
string value = (string)attribute;
headingNames.Add(xName);
valueNames.Add(value);
}
输出将是DataGridView上的DataTable。 它应该在另一个xml文件中使用@搜索Names并找到它们的值。但需要使用XMLDocument的代码..而不是使用linq ..任何人都可以帮助我吗?
答案 0 :(得分:1)
这方面的一个基本例子是:
List<string> valueNames = new List<string>();
List<string> headingNames = new List<string>();
XmlDocument doc = new XmlDocument();
doc.Load("data.xml");
for (int r = 0; r < doc.ChildNodes.Count; r++)
{
var currentNode = doc.ChildNodes.Item(r);
if (currentNode.Name.Equals("ROOT"))
{
var columnsNode = currentNode.FirstChild;
for (int i = 0; i < columnsNode.ChildNodes.Count; i++)
{
XmlNode child = columnsNode.ChildNodes.Item(i);
for (int j = 0; j < child.Attributes.Count; j++)
{
var attribute = child.Attributes.Item(j);
if (attribute.Name.Equals("XPath"))
{
headingNames.Add(attribute.Value);
}
else if (attribute.Name.Equals("Name"))
{
valueNames.Add(attribute.Value);
}
}
}
}
}
一些解释:
您的示例XML没有XML声明,因此我们可以让Root Element只是访问 FirstChild
属性。
编辑之后:您的示例XML现在有一个XML声明,但模式是相同的。 For循环并访问此循环的每个索引器的子元素。
&#39;列&#39;元素可以达到相同的方式。
在&#39;列上&#39;元素我们循环遍历所有子节点并使用循环的索引器(i)来获取相应的元素。为什么?因为它是XmlNodeList
对象。
使用我们的XmlNode child
我们也会这样做,但这次没有使用子节点。相反,我们遍历属性节点并寻找正确的名称。