ReplaceWith XElement
本文关键字:XElement ReplaceWith | 更新日期: 2023-09-27 18:29:07
下面是我的XDocument的内容片段。
<p style="">
<img id="Object3" src="Object3_png16malpha.png" width="78" height="37" />
</p>
<p style="">
<span>1 point: correct response of Point </span>X:
<img id="Object4" src="Object4_png16malpha.png" width="76" height="37" /> Point y:
<img id="Object5" src="Object5_png16malpha.png" width="78" height="37" /> Point z:
<img id="Object6" src="Object6_png16malpha.png" width="78" height="37" />.
<span style="">(1 point).</span>
</p>
<accessElement identifier="1234">
<contentLinkInfo LinkIdentifierRef="9_BEGIN" type="Text">
<objectLink />
</contentLinkInfo>
</accessElement>
基本上,我正在尝试用新内容替换每个图像<img>
标签。对于图像<Tag>
Object3 在处理后如下所示。
<span class="mathml" data-png="Object3_png16malpha.png" data-svg="Object3_png16malpha.svg">
<img id="Object3" alt="" src="Object3_png16malpha.png" />
</span>
但下面是我得到的输出,它跳过了一些我不确定的图像标签的处理。
<p style="">
<span class="mathml" data-png="Object3_png16malpha.png" data-svg="Object3_png16malpha.svg">
<img id="Object3" alt="" src="Object3_png16malpha.png" />
</span>
</p>
<p style="">
<span>1 point: correct response of Point </span>X:
<span class="mathml" data-png="Object4_png16malpha.png" data-svg="Object4_png16malpha.svg">
<img id="Object4" alt="" src="Object4_png16malpha.png" />
</span> Point y:
<img id="Object5" src="Object5_png16malpha.png" width="78" height="37" /> Point z:
<img id="Object6" src="Object6_png16malpha.png" width="78" height="37" />.
<span style="">(1 point).</span>
</p>
<accessElement identifier="1234">
<contentLinkInfo LinkIdentifierRef="9_BEGIN" type="Text">
<objectLink />
</contentLinkInfo>
</accessElement>
下面是我的代码片段
foreach (XElement bodyElement in uthDocument.Descendants().Elements())
{
if (bodyElement.Name == "img")
{
XElement newImageElement = getNewImageElement(bodyElement);
bodyElement.ReplaceWith(newImageElement);
}
}
我的代码确实跳过了最后两个图像元素的替换。
LINQ to XML 的结构类似于链表 - 每个节点都包含对其下一个节点的引用。
当您用新bodyElement
替换原始时,bodyElement
指向的下一个节点现在null
,因为您已将其从树中拉出。 因此,最有可能的是,您的一个迭代器将在此时中断并返回。
顺便说一句,您也不需要Elements()
调用,因为您最终会多次迭代大多数元素。 Descendants()
将返回下面的所有元素。
因此,只需急切地评估Descendants()
并对其进行迭代:
foreach (XElement bodyElement in uthDocument.Descendants().ToList())
{
...
}
理想情况下,您会在调用ToList()
之前对其进行过滤。 假设这是XHTML,这是相当简单的:
XNamespace xhtml = "http://www.w3.org/1999/xhtml";
var imgElements = uthDocument.Descendants(xhtml + "img").ToList();