c#操作xml文件之二
上一帖我们已经对xpath语法进行了简单的介绍,对xml文件的和操作数据库有一些相同之处,同样是增,删,改,查四种操作。现在我们就详细介绍一下增和删两种操作。看下面的一个xml示例:
xml的每个节点分为节点名称,节点值和属性三类,如:member节点:id为其一个属性,menber为其节点名称。再如:name节点456为其节点值。
如果我们需要增加一个节点可以调用一下几个方法:
如想要加入一个member的父节点,属性id值为7你可以这样来做:
则xml文件就会变成这样
向新添加的节点member(id=7)的节点下加入节点名称为qq,值为123456的新节点,你可以这样做
XmlHelper.XmlInsertElement(xmlPath, "//member[@id="7"]", "qq", "123456");
则输出的xml为:
下面我们介绍一下删除操作,删除共有两种,一是删除某一节点,一种是删除某一节点的属性。可以使用的方法如下:
假如我们向id=6的父节点下子节点qq节点加一属性sex值为‘男‘,从上面可以看出这是可以可以做到的,则xml文件就变为:
假如我们要删除sex=“男”,我们可以这样做 :
关键是xpath语法,只要你能找到你的目的节点就行!!
<?xml version="1.0" encoding="utf-8"?>
<phonebook>
<member id="6">
<name>456</name>
<qq>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
</phonebook>
<phonebook>
<member id="6">
<name>456</name>
<qq>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
</phonebook>
xml的每个节点分为节点名称,节点值和属性三类,如:member节点:id为其一个属性,menber为其节点名称。再如:name节点456为其节点值。
如果我们需要增加一个节点可以调用一下几个方法:
/// <summary>
/// 在根节点下添加父节点
/// </summary>
public static void AddParentNode(string xmlPath,string parentNode)
{
XmlDocument xdoc = new XmlDocument();
xdoc.Load(xmlPath);
// 创建一个新的menber节点并将它添加到根节点下
XmlElement Node = xdoc.CreateElement(parentNode);
xdoc.DocumentElement.PrependChild(Node);
xdoc.Save(xmlPath);
}
#region 插入一节点,带一属性
/// <summary>
/// 插入一节点,带一属性
/// </summary>
/// <param name="xmlPath">Xml文档路径</param>
/// <param name="MainNode">当前节点路径</param>
/// <param name="Element">新节点</param>
/// <param name="Attrib">属性名称</param>
/// <param name="AttribContent">属性值</param>
/// <param name="Content">新节点值</param>
public static void XmlInsertElement(string xmlPath, string MainNode, string Element, string Attrib, string AttribContent, string Content)
{
XmlDocument objXmlDoc = new XmlDocument();
objXmlDoc.Load(xmlPath);
XmlNode objNode = objXmlDoc.SelectSingleNode(MainNode);
XmlElement objElement = objXmlDoc.CreateElement(Element);
objElement.SetAttribute(Attrib, AttribContent);
objElement.InnerText = Content;
objNode.AppendChild(objElement);
objXmlDoc.Save(xmlPath);
}
#endregion
#region 插入一节点不带属性
public static void XmlInsertElement(string xmlPath, string MainNode, string Element, string Content)
{
XmlDocument objXmlDoc = new XmlDocument();
objXmlDoc.Load(xmlPath);
XmlNode objNode = objXmlDoc.SelectSingleNode(MainNode);
XmlElement objElement = objXmlDoc.CreateElement(Element);
objElement.InnerText = Content;
objNode.AppendChild(objElement);
objXmlDoc.Save(xmlPath);
}
#endregion
#region 向一个节点添加属性
/// <summary>
/// 向一个节点添加属性
/// </summary>
/// <param name="xmlPath">xml文件路径</param>
/// <param name="NodePath">节点路径</param>
/// <param name="NodeAttribute1">要添加的节点属性的名称</param>
/// <param name="NodeAttributeText">要添加属性的值</param>
public static void AddAttribute(string xmlPath, string NodePath, string NodeAttribute1, string NodeAttributeText)
{
XmlDocument objXmlDoc = new XmlDocument();
objXmlDoc.Load(xmlPath);
XmlAttribute nodeAttribute = objXmlDoc.CreateAttribute(NodeAttribute1);
XmlNode nodePath = objXmlDoc.SelectSingleNode(NodePath);
nodePath.Attributes.Append(nodeAttribute);
XmlElement xe = (XmlElement)nodePath;
xe.SetAttribute(NodeAttribute1, NodeAttributeText);
objXmlDoc.Save(xmlPath);
}
#endregion
/// 在根节点下添加父节点
/// </summary>
public static void AddParentNode(string xmlPath,string parentNode)
{
XmlDocument xdoc = new XmlDocument();
xdoc.Load(xmlPath);
// 创建一个新的menber节点并将它添加到根节点下
XmlElement Node = xdoc.CreateElement(parentNode);
xdoc.DocumentElement.PrependChild(Node);
xdoc.Save(xmlPath);
}
#region 插入一节点,带一属性
/// <summary>
/// 插入一节点,带一属性
/// </summary>
/// <param name="xmlPath">Xml文档路径</param>
/// <param name="MainNode">当前节点路径</param>
/// <param name="Element">新节点</param>
/// <param name="Attrib">属性名称</param>
/// <param name="AttribContent">属性值</param>
/// <param name="Content">新节点值</param>
public static void XmlInsertElement(string xmlPath, string MainNode, string Element, string Attrib, string AttribContent, string Content)
{
XmlDocument objXmlDoc = new XmlDocument();
objXmlDoc.Load(xmlPath);
XmlNode objNode = objXmlDoc.SelectSingleNode(MainNode);
XmlElement objElement = objXmlDoc.CreateElement(Element);
objElement.SetAttribute(Attrib, AttribContent);
objElement.InnerText = Content;
objNode.AppendChild(objElement);
objXmlDoc.Save(xmlPath);
}
#endregion
#region 插入一节点不带属性
public static void XmlInsertElement(string xmlPath, string MainNode, string Element, string Content)
{
XmlDocument objXmlDoc = new XmlDocument();
objXmlDoc.Load(xmlPath);
XmlNode objNode = objXmlDoc.SelectSingleNode(MainNode);
XmlElement objElement = objXmlDoc.CreateElement(Element);
objElement.InnerText = Content;
objNode.AppendChild(objElement);
objXmlDoc.Save(xmlPath);
}
#endregion
#region 向一个节点添加属性
/// <summary>
/// 向一个节点添加属性
/// </summary>
/// <param name="xmlPath">xml文件路径</param>
/// <param name="NodePath">节点路径</param>
/// <param name="NodeAttribute1">要添加的节点属性的名称</param>
/// <param name="NodeAttributeText">要添加属性的值</param>
public static void AddAttribute(string xmlPath, string NodePath, string NodeAttribute1, string NodeAttributeText)
{
XmlDocument objXmlDoc = new XmlDocument();
objXmlDoc.Load(xmlPath);
XmlAttribute nodeAttribute = objXmlDoc.CreateAttribute(NodeAttribute1);
XmlNode nodePath = objXmlDoc.SelectSingleNode(NodePath);
nodePath.Attributes.Append(nodeAttribute);
XmlElement xe = (XmlElement)nodePath;
xe.SetAttribute(NodeAttribute1, NodeAttributeText);
objXmlDoc.Save(xmlPath);
}
#endregion
如想要加入一个member的父节点,属性id值为7你可以这样来做:
//取得xml文件的路径
string xmlPath = Server.MapPath("~/test.xml");
string parentNode="member";
//在根节点下添加父节点member
XmlHelper.AddParentNode(xmlPath, parentNode);
//刚添加的member节点添加一
XmlHelper.AddAttribute(xmlPath, "phonebook/member", "id", "7");
string xmlPath = Server.MapPath("~/test.xml");
string parentNode="member";
//在根节点下添加父节点member
XmlHelper.AddParentNode(xmlPath, parentNode);
//刚添加的member节点添加一
XmlHelper.AddAttribute(xmlPath, "phonebook/member", "id", "7");
则xml文件就会变成这样
<?xml version="1.0" encoding="utf-8"?>
<phonebook>
<member id="6">
<name>456</name>
<qq>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
<member id="7">
</member>
</phonebook>
<phonebook>
<member id="6">
<name>456</name>
<qq>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
<member id="7">
</member>
</phonebook>
向新添加的节点member(id=7)的节点下加入节点名称为qq,值为123456的新节点,你可以这样做
XmlHelper.XmlInsertElement(xmlPath, "//member[@id="7"]", "qq", "123456");
<?xml version="1.0" encoding="utf-8"?>
<phonebook>
<member id="6">
<name>456</name>
<qq>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
<member id="7">
<qq>123456</qq>
</member>
</phonebook>
增加节点我们就介绍到这里,只要你基本掌握了xpath语法,融会贯通,就可以利用上面几个公用方法对xml文件进行增加操作<phonebook>
<member id="6">
<name>456</name>
<qq>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
<member id="7">
<qq>123456</qq>
</member>
</phonebook>
下面我们介绍一下删除操作,删除共有两种,一是删除某一节点,一种是删除某一节点的属性。可以使用的方法如下:
/// <summary>
/// 删除XML节点和此节点下的子节点
/// </summary>
/// <param name="xmlPath">xml文档路径</param>
/// <param name="Node">节点路径</param>
public static void XmlNodeDelete(string xmlPath, string Node)
{
XmlDocument objXmlDoc = new XmlDocument();
objXmlDoc.Load(xmlPath);
string mainNode = Node.Substring(0, Node.LastIndexOf("/"));
objXmlDoc.SelectSingleNode(mainNode).RemoveChild(objXmlDoc.SelectSingleNode(Node));
objXmlDoc.Save(xmlPath);
}
删除一个节点的属性
如要删除属性id值为5的节点(包括其子节点),我们可以这样做:/// 删除XML节点和此节点下的子节点
/// </summary>
/// <param name="xmlPath">xml文档路径</param>
/// <param name="Node">节点路径</param>
public static void XmlNodeDelete(string xmlPath, string Node)
{
XmlDocument objXmlDoc = new XmlDocument();
objXmlDoc.Load(xmlPath);
string mainNode = Node.Substring(0, Node.LastIndexOf("/"));
objXmlDoc.SelectSingleNode(mainNode).RemoveChild(objXmlDoc.SelectSingleNode(Node));
objXmlDoc.Save(xmlPath);
}
删除一个节点的属性
string xmlPath = Server.MapPath("~/test.xml");
XmlHelper.XmlNodeDelete(xmlPath, "phonebook / member[@id="5"]");
这时xml文件将变为:XmlHelper.XmlNodeDelete(xmlPath, "phonebook / member[@id="5"]");
<?xml version="1.0" encoding="utf-8"?>
<phonebook>
<member id="6">
<name>456</name>
<qq>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
<member id="7">
<qq>123456</qq>
</member>
</phonebook>
<phonebook>
<member id="6">
<name>456</name>
<qq>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
<member id="7">
<qq>123456</qq>
</member>
</phonebook>
<?xml version="1.0" encoding="utf-8"?>
<phonebook>
<member id="6">
<name>456</name>
<qq sex='男'>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
<member id="7">
<qq>123456</qq>
</member>
</phonebook>
<phonebook>
<member id="6">
<name>456</name>
<qq sex='男'>5465</qq>
</member>
<member id="5">
<name>jjjjj</name>
<qq>3456789</qq>
</member>
<member id="7">
<qq>123456</qq>
</member>
</phonebook>
假如我们要删除sex=“男”,我们可以这样做 :
XmlHelper.xmlnNodeAttributeDel(xmlPath, "//member[qq='5465']/qq", 'sex');
//也可以
XmlHelper.xmlnNodeAttributeDel(xmlPath, "//member[@id='6']/qq", 'sex');
//也可以
XmlHelper.xmlnNodeAttributeDel(xmlPath, "//member[@id='6']/qq", 'sex');
关键是xpath语法,只要你能找到你的目的节点就行!!