我有以下查询 XML 文件的方法。我需要它返回所有文件的信息,这些文件具有与我传递给我的方法的“sys”变量匹配的“系统”元素。
它工作正常,但只返回 1 个结果,当我知道 XML 文件中有超过 1 个匹配项时。
就好像我的 Linq 查询只是通过 XML 文件,直到找到结果然后停止,而我需要它来获取所有匹配项的集合。
public ListViewItem getDMcollection(string sys)
{
XDocument doc = XDocument.Load(Form1.CSDBpath + Form1.projectName + "\\Data.xml");
var dms = from dm in doc.Descendants("dataModule")
where dm.Descendants("system").First().Value == sys
select dm;
foreach (var module in dms)
{
ListViewItem item = new ListViewItem(new string[]
{
module.Element("DMC").Value,
module.Element("techName").Value,
module.Element("infoName").Value,
module.Element("status").Value,
module.Element("currentUser").Value,
module.Element("validator").Value,
module.Element("notes").Value,
//dm.Element("size").Value + " kb",
//dm.Element("dateMod").Value
});
return item;
}
return null;
}
这是 XML 文件的示例:
<DMs>
<dataModule>
<DMC>DMC-AJ-A-29-13-54-00ZZZ-254Z-B_001-00.XML</DMC>
<techName>Pressure switch</techName>
<infoName>Clean mechanically</infoName>
<system>72</system>
<subsystem>13</subsystem>
<subsubsystem>60</subsubsystem>
<status>Checked Out</status>
<notes>-</notes>
<currentUser>JakeMemery</currentUser>
<validator>-</validator>
<dateMod>-</dateMod>
<size>-</size>
</dataModule>
<dataModule>
<DMC>DMC-AJ-A-30-15-62-00AAA-066A-D_001-00.XML</DMC>
<techName>Pressure switch</techName>
<infoName>Support equipment and tools data</infoName>
<system>29</system>
<subsystem>13</subsystem>
<subsubsystem>54</subsubsystem>
<status>Checked In</status>
<notes>-</notes>
<currentUser>-</currentUser>
<validator>-</validator>
<dateMod>-</dateMod>
<size>-</size>
</dataModule>
<dataModule>
<DMC>DMC-AJ-A-45-60-12-00AAA-420A-B_001-00.XML</DMC>
<techName>Pressure switch</techName>
<infoName>General fault isolation procedure</infoName>
<system>29</system>
<subsystem>20</subsystem>
<subsubsystem>10</subsubsystem>
<status>Checked In</status>
<notes>-</notes>
<currentUser>-</currentUser>
<validator>-</validator>
<dateMod>-</dateMod>
<size>-</size>
</dataModule>
</DMs>
例如,我可能会将 29 的值传递给我的方法。如您所见,上面的 XML 文件包含两个 'System' 29 匹配项,但我的程序只返回其中 1 个 - 第一个。
调用上述方法并传入“sys”变量的方法是:
public ListViewItem splitSNS(string fullSNSpath)
{
string sns = new String(fullSNSpath.ToCharArray().Where(c => Char.IsDigit(c)).ToArray());
if (sns.Length.ToString() == "6")
{
string sys = sns.Substring(4, 2);
string subsys = sns.Substring(2, 2);
string unit = sns.Substring(0, 2);
ListViewItem dms = getDMcollection(sys, subsys, unit);
return dms;
}
else if (sns.Length.ToString() == "4")
{
string sys = sns.Substring(2, 2);
string subsys = sns.Substring(0, 2);
ListViewItem dms = getDMcollection(sys, subsys);
return dms;
}
else if (sns.Length.ToString() == "2")
{
string sys = sns.Substring(0, 2);
ListViewItem dms = getDMcollection(sys);
return dms;
}
return null;
}
调用上述方法的摘录是
ListViewItem dms = newFilter.splitSNS(fullSNSpath);
if (dms != null)
{
// showfilteredList(dms);
listView1.Items.Add(dms);
showStatus(dms);
}
else
{
MessageBox.Show("There are no DMs to be displayed");
}