<?xml version="1.0" encoding="utf-8"?>
<bookstore>
<!--记录书本的信息-->
<book Type="必修课" ISBN="7-111-19149-2">
<title>数据结构</title>
<author>严蔚敏</author>
<price>30.00</price>
</book>
<book Type="必修课" ISBN="7-111-19149-3">
<title>路由型与交换型互联网基础</title>
<author>程庆梅</author>
<price>27.00</price>
</book>
<book Type="必修课" ISBN="7-111-19149-4">
<title>计算机硬件技术基础</title>
<author>李继灿</author>
<price>25.00</price>
</book>
<book Type="必修课" ISBN="7-111-19149-5">
<title>软件质量保证与管理</title>
<author>朱少民</author>
<price>39.00</price>
</book>
<book Type="必修课" ISBN="7-111-19149-6">
<title>算法设计与分析</title>
<author>王红梅</author>
<price>23.00</price>
</book>
<book Type="选修课" ISBN="7-111-19149-1">
<title>计算机操作系统</title>
<author>7-111-19149-1</author>
<price>28</price>
</book>
</bookstore>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 使用XmlDocument
{
public class BookModel
{
public BookModel()
{ }
/// <summary>
/// 所对应的课程类型
/// </summary>
private string bookType;
public string BookType
{
get { return bookType; }
set { bookType = value; }
}
/// <summary>
/// 书所对应的ISBN号
/// </summary>
private string bookISBN;
public string BookISBN
{
get { return bookISBN; }
set { bookISBN = value; }
}
/// <summary>
/// 书名
/// </summary>
private string bookName;
public string BookName
{
get { return bookName; }
set { bookName = value; }
}
/// <summary>
/// 作者
/// </summary>
private string bookAuthor;
public string BookAuthor
{
get { return bookAuthor; }
set { bookAuthor = value; }
}
/// <summary>
/// 价格
/// </summary>
private double bookPrice;
public double BookPrice
{
get { return bookPrice; }
set { bookPrice = value; }
}
}
}
xn 代表一个结点 xn.Name;//这个结点的名称 xn.Value;//这个结点的值 xn.ChildNodes;//这个结点的所有子结点 xn.ParentNode;//这个结点的父结点 .......
XmlDocument doc = new XmlDocument(); doc.Load(@"..\..\Book.xml");
// 得到根节点bookstore
XmlNode xn = xmlDoc.SelectSingleNode("bookstore");
// 得到根节点的所有子节点
XmlNodeList xnl = xn.ChildNodes;
foreach (XmlNode xn1 in xnl)
{
BookModel bookModel = new BookModel();
// 将节点转换为元素,便于得到节点的属性值
XmlElement xe = (XmlElement)xn1;
// 得到Type和ISBN两个属性的属性值
bookModel.BookISBN = xe.GetAttribute("ISBN").ToString();
bookModel.BookType = xe.GetAttribute("Type").ToString();
// 得到Book节点的所有子节点
XmlNodeList xnl0 = xe.ChildNodes;
bookModel.BookName=xnl0.Item(0).InnerText;
bookModel.BookAuthor=xnl0.Item(1).InnerText;
bookModel.BookPrice=Convert.ToDouble(xnl0.Item(2).InnerText);
bookModeList.Add(bookModel);
}
dgvBookInfo.DataSource = bookModeList;
XmlDocument xmlDoc = new XmlDocument(); XmlReaderSettings settings = new XmlReaderSettings(); settings.IgnoreComments = true;//忽略文档里面的注释 XmlReader reader = XmlReader.Create(@"..\..\Book.xml", settings); xmlDoc.Load(reader);
reader.Close();
XmlDocument doc = new XmlDocument();
doc.Load(@"..\..\Book.xml");
XmlNode root = doc.SelectSingleNode("bookstore");
XmlElement xelKey = doc.CreateElement("book");
XmlAttribute xelType = doc.CreateAttribute("Type");
xelType.InnerText = "adfdsf";
xelKey.SetAttributeNode(xelType);
XmlElement xelAuthor = doc.CreateElement("author");
xelAuthor.InnerText = "dfdsa";
xelKey.AppendChild(xelAuthor);
root.AppendChild(xelKey); doc.Save(@"..\..\Book.xml");
XmlDocument doc = new XmlDocument();
doc.LoadXml("<bookstore></bookstore>");//用这句话,会把以前的数据全部覆盖掉,只有你增加的数据
XmlElement xe = xmlDoc.DocumentElement; // DocumentElement 获取xml文档对象的根XmlElement.
string strPath = string.Format("/bookstore/book[@ISBN=\"{0}\"]", dgvBookInfo.CurrentRow.Cells[1].Value.ToString());
XmlElement selectXe = (XmlElement)xe.SelectSingleNode(strPath); //selectSingleNode 根据XPath表达式,获得符合条件的第一个节点.
selectXe.ParentNode.RemoveChild(selectXe);
XmlElement xe = xmlDoc.DocumentElement; // DocumentElement 获取xml文档对象的根XmlElement.
string strPath = string.Format("/bookstore/book[@ISBN=\"{0}\"]", dgvBookInfo.CurrentRow.Cells[1].Value.ToString());
XmlElement selectXe = (XmlElement)xe.SelectSingleNode(strPath); //selectSingleNode 根据XPath表达式,获得符合条件的第一个节点.
selectXe.SetAttribute("Type", dgvBookInfo.CurrentRow.Cells[0].Value.ToString());//也可以通过SetAttribute来增加一个属性
selectXe.GetElementsByTagName("title").Item(0).InnerText = dgvBookInfo.CurrentRow.Cells[2].Value.ToString();
selectXe.GetElementsByTagName("author").Item(0).InnerText = dgvBookInfo.CurrentRow.Cells[3].Value.ToString();
selectXe.GetElementsByTagName("price").Item(0).InnerText = dgvBookInfo.CurrentRow.Cells[4].Value.ToString();
xmlDoc.Save(@"..\..\Book.xml");
XmlTextReader reader = new XmlTextReader(@"..\..\Book.xml");
List<BookModel> modelList = new List<BookModel>();
BookModel model = new BookModel();
while (reader.Read())
{
if (reader.NodeType == XmlNodeType.Element)
{
if (reader.Name == "book")
{
model.BookType = reader.GetAttribute(0);
model.BookISBN = reader.GetAttribute(1);
}
if (reader.Name == "title")
{
model.BookName=reader.ReadElementString().Trim();
}
if (reader.Name == "author")
{
model.BookAuthor = reader.ReadElementString().Trim();
}
if (reader.Name == "price")
{
model.BookPrice = Convert.ToDouble(reader.ReadElementString().Trim());
}
}
if (reader.NodeType == XmlNodeType.EndElement)
{
modelList.Add(model);
model = new BookModel();
}
}
modelList.RemoveAt(modelList.Count-1);
this.dgvBookInfo.DataSource = modelList;
if (reader.Name == "book")
{
for (int i = 0; i < reader.AttributeCount; i++)
{
reader.MoveToAttribute(i);
string str = "属性:" + reader.Name + "=" + reader.Value;
}
model.BookType = reader.GetAttribute(0);
model.BookISBN = reader.GetAttribute(1);
}
XmlTextWriter myXmlTextWriter = new XmlTextWriter(@"..\..\Book1.xml", null); //使用 Formatting 属性指定希望将 XML 设定为何种格式。 这样,子元素就可以通过使用 Indentation 和 IndentChar 属性来缩进。 myXmlTextWriter.Formatting = Formatting.Indented;
XmlTextWriter myXmlTextWriter = new XmlTextWriter(@"..\..\Book1.xml", null);
//使用 Formatting 属性指定希望将 XML 设定为何种格式。 这样,子元素就可以通过使用 Indentation 和 IndentChar 属性来缩进。
myXmlTextWriter.Formatting = Formatting.Indented;
myXmlTextWriter.WriteStartDocument(false);
myXmlTextWriter.WriteStartElement("bookstore");
myXmlTextWriter.WriteComment("记录书本的信息");
myXmlTextWriter.WriteStartElement("book");
myXmlTextWriter.WriteAttributeString("Type", "选修课");
myXmlTextWriter.WriteAttributeString("ISBN", "111111111");
myXmlTextWriter.WriteElementString("author","张三");
myXmlTextWriter.WriteElementString("title", "职业生涯规划");
myXmlTextWriter.WriteElementString("price", "16.00");
myXmlTextWriter.WriteEndElement();
myXmlTextWriter.WriteEndElement();
myXmlTextWriter.Flush();
myXmlTextWriter.Close();
private void showInfoByElements(IEnumerable<XElement> elements)
{
List<BookModel> modelList = new List<BookModel>();
foreach (var ele in elements)
{
BookModel model = new BookModel();
model.BookAuthor = ele.Element("author").Value;
model.BookName = ele.Element("title").Value;
model.BookPrice = Convert.ToDouble(ele.Element("price").Value);
model.BookISBN=ele.Attribute("ISBN").Value;
model.BookType=ele.Attribute("Type").Value;
modelList.Add(model);
}
dgvBookInfo.DataSource = modelList;
}
private void btnReadAll_Click(object sender, EventArgs e)
{
XElement xe = XElement.Load(@"..\..\Book.xml");
IEnumerable<XElement> elements = from ele in xe.Elements("book")
select ele;
showInfoByElements(elements);
}
private void btnInsert_Click(object sender, EventArgs e)
{
XElement xe = XElement.Load(@"..\..\Book.xml");
XElement record = new XElement(
new XElement("book",
new XAttribute("Type", "选修课"),
new XAttribute("ISBN","7-111-19149-1"),
new XElement("title", "计算机操作系统"),
new XElement("author", "7-111-19149-1"),
new XElement("price", 28.00)));
xe.Add(record);
xe.Save(@"..\..\Book.xml");
MessageBox.Show("插入成功!");
btnReadAll_Click(sender, e);
}
private void btnDelete_Click(object sender, EventArgs e)
{
if (dgvBookInfo.CurrentRow != null)
{
//dgvBookInfo.CurrentRow.Cells[1]对应着ISBN号
string id = dgvBookInfo.CurrentRow.Cells[1].Value.ToString();
XElement xe = XElement.Load(@"..\..\Book.xml");
IEnumerable<XElement> elements = from ele in xe.Elements("book")
where (string)ele.Attribute("ISBN") == id
select ele;
{
if (elements.Count() > 0)
elements.First().Remove();
}
xe.Save(@"..\..\Book.xml");
MessageBox.Show("删除成功!");
btnReadAll_Click(sender, e);
}
}
private void btnDeleteAll_Click(object sender, EventArgs e)
{
XElement xe = XElement.Load(@"..\..\Book.xml");
IEnumerable<XElement> elements = from ele in xe.Elements("book")
select ele;
if (elements.Count() > 0)
{
elements.Remove();
}
xe.Save(@"..\..\Book.xml");
MessageBox.Show("删除成功!");
btnReadAll_Click(sender, e);
}
private void btnSave_Click(object sender, EventArgs e)
{
XElement xe = XElement.Load(@"..\..\Book.xml");
if (dgvBookInfo.CurrentRow != null)
{
//dgvBookInfo.CurrentRow.Cells[1]对应着ISBN号
string id = dgvBookInfo.CurrentRow.Cells[1].Value.ToString();
IEnumerable<XElement> element = from ele in xe.Elements("book")
where ele.Attribute("ISBN").Value == id
select ele;
if (element.Count() > 0)
{
XElement first = element.First();
///设置新的属性
first.SetAttributeValue("Type", dgvBookInfo.CurrentRow.Cells[0].Value.ToString());
///替换新的节点
first.ReplaceNodes(
new XElement("title", dgvBookInfo.CurrentRow.Cells[2].Value.ToString()),
new XElement("author", dgvBookInfo.CurrentRow.Cells[3].Value.ToString()),
new XElement("price", (double)dgvBookInfo.CurrentRow.Cells[4].Value)
);
}
xe.Save(@"..\..\Book.xml");
MessageBox.Show("修改成功!");
btnReadAll_Click(sender, e);
}
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有