Linq to XML - 查找一个元素

8

我确定这是基础问题,可能以前已经被问过了,但我刚开始使用 Linq to XML。

我有一个简单的 XML 需要读取和写入。

<Documents>
...
    <Document>
      <GUID>09a1f55f-c248-44cd-9460-c0aab7c017c9-0</GUID>
      <ArchiveTime>2012-05-15T14:27:58.5270023+02:00</ArchiveTime>
      <ArchiveTimeUtc>2012-05-15T12:27:58.5270023Z</ArchiveTimeUtc>
      <IndexDatas>
        <IndexData>
          <Name>Name1</Name>
          <Value>Some value</Value>
          <DataType>1</DataType>
          <CreationTime>2012-05-15T14:27:39.6427753+02:00</CreationTime>
          <CreationTimeUtc>2012-05-15T12:27:39.6427753Z</CreationTimeUtc>
        </IndexData>
        <IndexData>
          <Name>Name2</Name>
          <Value>Some value</Value>
          <DataType>3</DataType>
          <CreationTime>2012-05-15T14:27:39.6427753+02:00</CreationTime>
          <CreationTimeUtc>2012-05-15T12:27:39.6427753Z</CreationTimeUtc>
        </IndexData>
   ...
 </IndexDatas>
</Document>
...
</Documents>

我有一个包含许多“文档”节点的“文档”节点。

我有文件的GUID和“IndexData”名称。 我需要通过GUID查找文档,并检查它是否具有某个名称的“IndexData”。 如果没有,我需要添加它。

任何帮助都将不胜感激,因为我在阅读和搜索元素方面遇到了问题。

目前我正在尝试使用(在C#中):

IEnumerable<XElement> xmlDocuments = from c in XElement
                                        .Load(filePath)
                                        .Elements("Documents") 
                                         select c;

// fetch document
 XElement documentElementToEdit = (from c in xmlDocuments where 
                    (string)c.Element("GUID").Value == GUID select c).Single();

编辑

xmlDocuments.Element("Documents").Elements("Document")

即使 xmlDocuments.Element("Documents") 正常返回结果,但是这段代码没有任何返回值。看起来我无法从 Documents 节点中获取 Document 节点。

2个回答

9

您可以使用以下代码查找那些没有相关名称的文档(即索引数据中没有相关名称的文档),然后您可以将您的元素添加到IndexData元素的末尾。

var relatedDocs = doc.Elements("Document")
   .Where(x=>x.Element("GUID").Value == givenValue)
   .Where(x=>!x.Element("IndexDatas")
              .Elements("IndexData")
              .Any(x=>x.Element("Name") == someValue);

1
我认为应该是 doc.Descendants("Document") - Andras Zoltan

0

这应该可以工作:

var x = XDocument.Load(filePath);
// guid in your sample xml is not a valid guid, so I changed it to a random valid one
var requiredGuid = new Guid("E61D174C-9048-438D-A532-17311F57ED9B");
var requiredName = "Name1";

var doc = x.Root
           .Elements("Document")
           .Where(d => (Guid)d.Element("GUID") == requiredGuid)
           .FirstOrDefault();
if(doc != null)
{
    var data = doc.Element("IndexDatas")
                  .Elements("IndexData")
                  .Where(d => (string)d.Element("Name") == requiredName)
                  .FirstOrDefault();
    if(data != null)
    {
        // index data found
    }
    else
    {
        // index data not found
    }
}
else
{
    // document not found
}

你好。GUID是错误的,但应该被视为简单字符串。但我没有得到任何文档(doc为空)! - no9

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接