xml文件中两个重名的子节点该怎么添加

xml文件中两个重名的子节点该怎么添加,第1张

在xml文件有多个命名空间时,你的xml各种类型中的元素在没有确切指明其命名空间的情况下,它的命名空间就是默认命名空间(一般问xml文档根节点中指定命名空间的第一个属性)。当你添加节点时,若没有指明该节点的命名空间时,不会使用默认命名空间的,会添加:xmls=“”,作为默认命名空间。

所以,解决的方式当然就是在添加节点时就指明其命名空间就是咯。

命名空间使用方法:

XmlNamespaceManager nsmgr = new XmlNamespaceManager(new XmlDocument().NameTable) //声明一个命名空间管理器

nsmgr.AddNamespace(“ns”, xmlUrl)//向管理器添加一个命名空间连接,其中ns为添加命名空间的名称,xmlUrl为命名空间的链接。两个参数都是string类型。

jobNode.SelectSingleNode("ns:trigger/ns:cron", nsmgr)//使用命名空间查找节点。注意其中的ns和nsmgr

其实对于你的问题只需要在创建要加入的节点时指明一个xmlUrl就可以啦:

XmlElement jobElement = xmlDoc.CreateElement("job", xmlUrl)

能,

C# *** 作XML时,要引入命名空间using System.Xml

获取根节点的方法:

1、知道根节点名称:

XmlNode root = xmlDoc.SelectSingleNode("根节点名称")

2、不知道根节点名称:

XmlElement root = xmlDoc.DocumentElement

xml中node(节点)和element(元素)的区别(还是不太明白)

1、element是一个小范围的定义,必须含有完整信息的结点才能叫做元素。例如:<div>内容</div>,一个元素一定是一个节点,一个节点不一定是一个元素。

2、node是基本对象,attribute,element,text等都是node的子对象。

创建节点

1、CreateElement() 方法

有一个参数,两个参数,三个参数三种重载,参数类型均为string。

一个参数:CreateElement("元素名称")

两个参数:CreateElement("元素名称","元素的命名空间")

三个参数:CreateElement("元素的前缀","元素的名称","元素的命名空间")

2、CreateNode() 方法

三个参数 都为string类型

CreateNode("节点类型","节点名称","节点命名空间")

四个参数 都为string类型

CreateNode("节点类型","节点的前缀","节点名称","节点命名空间")

问题:节点前缀有什么作用?结点命名空间有什么作用?

增加节点:

1、AppendChild() 方法

2、InsertAfter(要插入的节点,参考节点) 方法

3、InsertBefore(要插入的节点,参考节点) 方法

增加节点属性:

SetAttribute("属性名","属性值")方法

删除节点属性:

RemoveAttribute("属性名称")

给节点添加数据:

1、给节点的innerText赋值

例子:XmlElement eName = doc.CreateElement("name")

eName.InnerText = aaaaa

2、添加XmlText节点,为其添加值

添加节点元素

将XmlText以子节点的方式添加给节点元素

例子: XmlElement eName = xmlDoc.CreateElement("name")

XmlText tName = xmlDoc.CreateTextNode(aaaaa)

eName.AppendChild(tName)

寻找某个节点(寻找name节点):

先找到根节点,找出根节点下的节点列表(XmlNodeList),遍历每个节点。

再找每个节点下的节点列表,进行遍历,指导找到所需要的节点。

<msg>

<name></name>

<content></content>

</msg>

方法:

XmlNode root = xmlDoc.SelectSingleNode("msg")

XmlNodeList nodeList = root.ChildNodes

foreach (XmlNode node in nodeList)

{

if(node.Name=="name")

{

找到name节点,进行 *** 作

}

}

删除节点

RemoveAll(无参数)

RemoveChild(要移除的节点)

更新节点

1、ReplaceChild(新节点,老节点)

建立一个新节点,替换老节点

2、找到要更新的节点,重新设置其属性和数据

用GridView显示xml文件中的数据

view plaincopy to clipboardprint?

DataSet ds = new DataSet()

ds.ReadXml(Server.MapPath("BooksInfo.xml"))

GridView1.DataSource = ds.Tables[0]

GridView1.DataBind()

DataSet ds = new DataSet()

ds.ReadXml(Server.MapPath("BooksInfo.xml"))

GridView1.DataSource = ds.Tables[0]

GridView1.DataBind()

xml文件

view plaincopy to clipboardprint?

<?xml version="1.0" encoding="utf-8"?>

<bookstore>

<book genre="ee" ISBN="2-3631-4">

<title>三国演义</title>

<author>lfdfd</author>

<price>55.95</price>

</book>

<book ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>涨红</author>

<price>58.3</price>

</book>

<book genre="计算机" ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>盖茨</author>

<price>58.3</price>

</book>

<book genre="计算机" ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>盖茨</author>

<price>58.3</price>

</book>

</bookstore>

<?xml version="1.0" encoding="utf-8"?>

<bookstore>

<book genre="ee" ISBN="2-3631-4">

<title>三国演义</title>

<author>lfdfd</author>

<price>55.95</price>

</book>

<book ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>涨红</author>

<price>58.3</price>

</book>

<book genre="计算机" ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>盖茨</author>

<price>58.3</price>

</book>

<book genre="计算机" ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>盖茨</author>

<price>58.3</price>

</book>

</bookstore>

显示效果:

删除属性为计算机的节点

view plaincopy to clipboardprint?

XmlDocument xmlDoc = new XmlDocument()

xmlDoc.Load(Server.MapPath("xml/BooksInfo.xml"))

XmlNodeList xnl = xmlDoc.SelectSingleNode("bookstore").ChildNodes

foreach (XmlNode xn in xnl)

{

XmlElement xe = (XmlElement)xn

if (xe.GetAttribute("genre") == "计算机")

{

xe.RemoveAll()//删除属性=计算机的该节点的全部内容

//xe.ParentNode.RemoveChild(xe)

}

}

xmlDoc.Save(Server.MapPath("xml/BooksInfo.xml"))

XmlDocument xmlDoc = new XmlDocument()

xmlDoc.Load(Server.MapPath("xml/BooksInfo.xml"))

XmlNodeList xnl = xmlDoc.SelectSingleNode("bookstore").ChildNodes

foreach (XmlNode xn in xnl)

{

XmlElement xe = (XmlElement)xn

if (xe.GetAttribute("genre") == "计算机")

{

xe.RemoveAll()//删除属性=计算机的该节点的全部内容

//xe.ParentNode.RemoveChild(xe)

}

}

xmlDoc.Save(Server.MapPath("xml/BooksInfo.xml"))

xe.ParentNode.RemoveChild(xe)

寻找到xe节点的父节点,再删除他的子节点。那么此节点(包括节点标记)将不存在。显示中将没有空行

xe.RemoveAll()

移除节点内容,但是节点标签还在。显示中有空行


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/bake/7994334.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-12
下一篇 2023-04-12

发表评论

登录后才能评论

评论列表(0条)

保存