0
<sg>
       <userdata>
            <data>
             <tag name="gf" description="fg" nodeid="                                                      {2F2CC6951E2B4EEA979F357164CB73E5}" controllerid="" keytype="" mask="" track="widthsegment"    numkey="" interpolator="" frame="" aindex="1" number="1">
              <![CDATA[  //sg/objects/object[@id="          {2F2CC6951E2B4EEA979F357164CB73E5}"]/params/param[@name="widthsegment"]
               ]]> 
               </tag>
              <tag name="gf" description="fg" nodeid="               {2F2CC6951E2B4EEA979F357164CB73E5}" controllerid="" keytype="" mask="" track="widthsegment"                       numkey="" interpolator="" frame="" aindex="1" number="2">
               <![CDATA[  //sg/objects/object[@id="                         {2F2CC6951E2B4EEA979F357164CB73E5}"]/params/param[@name="widthsegment"]
              ]]> 
              </tag>
                </data>
               </userdata>
                    </sg>

我想从中删除“标签”-标签怎么做

我做了这样的

updatedData.SelectSingleNode("//tag[@name='" + 1 + "']").RemoveAll(); 

但是标签仍然出现在这个..我的意思是空标签..如何删除它

之后

                   <sg>
                    <userdata>
                      <data>
                      <tag /> --- This is wat i want to remove... how to remove this
                       <tag name="gf" description="fg" nodeid="        {2F2CC6951E2B4EEA979F357164CB73E5}" controllerid="" keytype="" mask="" track="widthsegment"      numkey="" interpolator="" frame="" aindex="1" number="2">
                      <![CDATA[  //sg/objects/object[@id="           {2F2CC6951E2B4EEA979F357164CB73E5}"]/params/param[@name="widthsegment"]
                    ]]> 
                     </tag>
                      </data>

4

4 回答 4

1
XmlNodeList nodes = updatedData.GetElementsByTagName("tagname");
foreach (XmlNode node in nodes)
{
    if (node.ChildNodes.Count == 0)
        node.RemoveAll();
    else
        UpdateDoc.InnerXml = node.OuterXml;
}

我解决了这个...

于 2012-11-20T09:38:45.463 回答
0
var xmlDoc = XDocument.Load("filename.xml");
var element = (
    from x in xmlDoc.Root.Elements("elemnt-name")
    where x.Element("tage-name").Value == "xxxx"
    select x
    ).FirstOrDefault();
element.Remove();
xmlDoc .Save("filename.xml");
于 2012-11-16T11:39:05.623 回答
0

你的 XPath 很奇怪:

"//tag[@name='" + 1 + "']"

它将选择属性值为 1 的所有tag元素。您的示例中没有。name

您还使用SelectSingleNodewhich 只会选择一个节点。

"//tag"如果您希望全部选择XPath,则应该使用 XPath ,并且应该SelectNodes改用 XPath。

于 2012-11-16T11:40:14.407 回答
0

这就是您将 xdocument 加载到 XmlNodeList 的方式

 XDocument doc = XDocument.Load(@"C:\Users\sghaida\Documents\Visual Studio 2008\Projects\testing-ws-1\XMLParser\config.xml");
                XmlDocument xmlDoc = new XmlDocument();
                XmlNodeReader nodeReader = (XmlNodeReader)doc.CreateReader();
                xmlDoc.ReadNode(nodeReader);
                XmlNodeList xmlnodeList = xmlDoc.SelectNodes("node");
于 2012-11-16T12:11:38.293 回答