上一篇中讲到XML基本的结构,还有增删改查的方法,这一篇中我们就来利用XML来完成一个简单的订单系统,主要是实现一个简单学生名单的增删改查,如果想要应用到实际的环境中建议考虑数据量的问题,如果数据量大使用XML的话会比较耗时,使用SQL的性能会好一些
这里使用WinForm窗体程序,大致界面如下:
- 创建了两个窗体,一个主窗体用来显示名单数据,当添加或者编辑操作时则使用另外一个窗体。
- 主窗体中放置四个按钮,以及一个DataGridView控件,另外一个添加、编辑窗体,则按照相应的字段放置好控件。
- 给各控件命好名。
XML文档的格式如下:
<?xml version="1.0" encoding="utf-8"?> <学生名单> <学生 Name="李四一" class="0102"> <性别>男</性别> <生日>1999年1月2日</生日> <学号>20170</学号> </学生> <学生 Name="张三三" class="高一"> <性别>男</性别> <学号>0102</学号> <生日>2017年6月18日</生日> </学生> </学生名单>
学生名单为根元素,班级为根元素中的子元素,班级中又嵌套<学生>标记,了解了数据是以怎么的结构储存那么下面就继续。
数据在DataGridView中的显示
将XML中的数据,顺序显示在DataGridView控件中
//创建一个datatable存储XML中的数据 DataTable dt = new DataTable(); //指定每一列的列名,和数据类型 dt.Columns.Add("Id", (typeof(System.String))); dt.Columns.Add("班级", (typeof(System.String))); dt.Columns.Add("姓名", (typeof(System.String))); dt.Columns.Add("学号", (typeof(System.String))); dt.Columns.Add("生日", (typeof(System.String))); dt.Columns.Add("性别", (typeof(System.String))); //创建一个DataRow对象 DataRow dr = dt.NewRow(); XmlDocument doc = new XmlDocument(); //为相对路径表示前二级的目录 doc.Load(@"..//..//Students.xml"); XmlElement root = doc.DocumentElement; XmlNodeList studentNodes = root.GetElementsByTagName("学生"); //使用foreach遍历集合元素 foreach(var item in studentNodes) { dr["Id"] = ((XmlElement)item).GetAttribute("Id"); dr["班级"] = ((XmlElement)item).GetAttribute("Class"); dr["姓名"] = ((XmlElement)item).GetAttribute("Name"); dr["学号"] = ((XmlElement)item).GetElementsByTagName("学号")[].InnerText; dr["生日"] = ((XmlElement)item).GetElementsByTagName("生日")[].InnerText; dr["性别"] = ((XmlElement)item).GetElementsByTagName("性别")[].InnerText; dt.Rows.Add(dr); } //将DataTable绑定到DataGridView控件 dgvStudents.DataSource = dt;
增加记录
因为添加学生和编辑学生都需要在同一个窗体,那么在打开添加或编辑窗体时使用构造函数来传值,并判断是编辑还是添加。
添加编辑窗体代码: public partial class FrmStudentAddandEdit : Form { //全局变量接受传值 bool IsAdd; string Name; //使用构造函数进行传值 true为增加,false为编辑 public FrmStudentAddandEdit(bool isAdd, string name) { this.IsAdd = isAdd; this.Name = name; InitializeComponent(); } } 主窗体添加按钮单击事件代码: private void btnAdd_Click(object sender, EventArgs e) { //在创建窗体时传值 FrmStudentAddandEdit form = new FrmStudentAddandEdit(true); form.ShowDialog(); } 新增记录代码: private void btnOK_Click(object sender, EventArgs e) { XmlDocument doc = new XmlDocument(); doc.Load(@"..//..//Students.xml"); XmlElement root = doc.DocumentElement; //添加<学生>子节点 XmlElement Shutdent = doc.CreateElement("学生"); //设置Name属性和Class属性 Shutdent.SetAttribute("Name", txtName.Text.Trim()); Shutdent.SetAttribute("Class", txtClass.Text.Trim()); //创建子节点 XmlElement eSex = doc.CreateElement("性别"); XmlText tSex = doc.CreateTextNode(cmbSex.Text.Trim()); //子节点添加内容 eSex.AppendChild(tSex); //将子节点添加进学生标记 Shutdent.AppendChild(eSex); XmlElement eNum = doc.CreateElement("学号"); XmlText tNum = doc.CreateTextNode(txtNumber.Text.Trim()); eNum.AppendChild(tNum); Shutdent.AppendChild(eNum); XmlElement eBirthday = doc.CreateElement("生日"); XmlText tBirthday = doc.CreateTextNode(dtpBirthday.Text.Trim('-')); eBirthday.AppendChild(tBirthday); Shutdent.AppendChild(eBirthday); //将<学生>标记添加进根节点 root.AppendChild(Shutdent); doc.Save(@"..//..//Students.xml"); MessageBox.Show("添加成功!"); this.Close(); }
编辑记录
由于编辑需要查找到这条记录然后复制到控件中显示,那么在我们启动”添加或编辑窗体”时需要判断当前是添加状态还是编辑状态,并将表格选择行的姓名字段传给构造函数,通过这个姓名字段查找相应的值,然后筛选出来再给控件赋值。
主窗口编辑按钮单击事件: private void btnEdit_Click(object sender, EventArgs e) { //获取当前选择表格的行索引 int dgvIndex = dgvStudents.CurrentRow.Index; //根据行索引获取单元格的值 string name = dgvStudents.Rows[dgvIndex].Cells["姓名"].Value.ToString(); FrmStudentAddandEdit form = new FrmStudentAddandEdit(false,name); form.ShowDialog(); } 窗体启动事件进行判断是添加还是编辑: private void FrmStudentAddandEdit_Load(object sender, EventArgs e) { if (IsAdd) { this.Text = "添加学生"; } else { this.Text = "编辑学生名单"; XmlDocument doc = new XmlDocument(); doc.Load(@"..//..//Students.xml"); XmlElement root = doc.DocumentElement; //筛选出符合条件的标记 XmlElement selectEle = (XmlElement)root.SelectSingleNode("/学生名单/学生[@Name='" + Name + "']"); //筛选出符合条件并给控件赋值 txtName.Text = selectEle.GetAttribute("Name"); txtClass.Text = selectEle.GetAttribute("Class"); txtNumber.Text = selectEle.GetElementsByTagName("学号")[].InnerText; dtpBirthday.Text = selectEle.GetElementsByTagName("生日")[].InnerText; cmbSex.Text = selectEle.GetElementsByTagName("性别")[].InnerText; } } 同样在编辑好内容后,单击确定按钮后判断当前是添加状态还是编辑状态: private void btnOK_Click(object sender, EventArgs e) { if (IsAdd) { //添加记录代码…. } else { this.Text = "编辑学生名单"; XmlDocument doc = new XmlDocument(); doc.Load(@"..//..//Students.xml"); XmlElement root = doc.DocumentElement; //筛选出符合条件的标记 XmlElement selectEle = (XmlElement)root.SelectSingleNode("/学生名单/学生[@Name='" + Name + "']"); selectEle.SetAttribute("Name",txtName.Text.Trim()); selectEle.SetAttribute("Class",txtClass.Text.Trim()); //筛选出的对象赋给XMLElement对象 XmlElement eSex = (XmlElement)selectEle.GetElementsByTagName("性别")[]; eSex.InnerText = cmbSex.Text; XmlElement eNumber = (XmlElement)selectEle.GetElementsByTagName("学号")[]; eNumber.InnerText = txtNumber.Text; XmlElement eBirth = (XmlElement)selectEle.GetElementsByTagName("生日")[]; eBirth.InnerText = dtpBirthday.Text; doc.Save(@"..//..//Students.xml"); MessageBox.Show("修改成功!"); //这一步很重要一定要关闭窗口不然再次修改会出现不可预料的BUG this.Close(); } }
删除记录
也是一样的逻辑获取当前选择表格的姓名字段,然后按照相关姓名进行删除,如果姓名不是唯一字段,那么可以使用ID,每次添加一条记录的时候最大ID+1。
//获取当前选择表格的行索引及姓名 int dgvIndex = dgvStudents.CurrentRow.Index; string name = dgvStudents.Rows[dgvIndex].Cells["姓名"].Value.ToString(); //筛选出符合条件的标记 XmlElement selectEle = (XmlElement)root.SelectSingleNode("/学生名单/学生[@Name='" + Name + "']"); //删除指定子元素 root.RemoveChild(selectEle); doc.Save(“…”); //具体代码省略。。。。。不会的同学可以回到上篇文章。
上面介绍的操作方法是最常使用几种的,可以使用XML来完成一个数据量比较小的软件,或者可以用来做软件的配置文件。
C#基础知识-使用XML完成一个小程序(十一)的更多相关文章
-
java操作xml的一个小例子
最近两天公司事比较多,这两天自己主要跟xml打交道,今天更一下用java操作xml的一个小例子. 原来自己操作xml一直用这个包:xstream-1.4.2.jar.然后用注解的方式,很方便,自己只要 ...
-
c++学习笔记---02---从一个小程序说起
从一个小程序说起 这一讲的主要目的是帮助大家在C语言的背景知识上与C++建立联系. 问题探索 问题:对一个整型数组求和. 要求:定义一个存储着 n 个元素的数组,要求用C语言完成这个任务. 赶紧的:大 ...
-
Python 练习冊,每天一个小程序
Python 练习冊,每天一个小程序 说明: Github 原文地址: 点击打开链接 Python 练习冊.每天一个小程序.注:将 Python 换成其它语言,大多数题目也试用 不会出现诸如「 ...
-
【Java】一个小程序,计算它包含的代码所需的耗时
写一个小程序,用来计算它包含的代码所需的耗时.虽然简单,测试代码是否耗时还是有点用的,不用重新写嘛~ import java.util.Date; import java.util.concurren ...
-
c++学习笔记---04---从另一个小程序接着说
从另一个小程序接着说 文件I/O 前边我们已经给大家简单介绍和演示过C和C++在终端I/O处理上的异同点. 现在我们接着来研究文件I/O. 编程任务:编写一个文件复制程序,功能实现将一个文件复制到另一 ...
-
c++学习笔记---03---从一个小程序说起2
从一个小程序说起2 要求:编写一个程序,要求用户输入一串整数和任意数目的空格,这些整数必须位于同一行中,但允许出现在该行中的任何位置.当用户按下键盘上的"Enter"键时,数据输入 ...
-
微信小程序开发——打开另一个小程序
微信小程序打开另一个小程序,有两种方法:1.超链接:2.点击按钮. 全局配置: 跳转到其他小程序,需要在当前小程序全局配置中配置需要跳转的小程序列表,代码如下: App.json { ... &quo ...
-
微信小程序如何跳转到另一个小程序
微信小程序如何跳转到另一个小程序,要注意:在app.json文件里也要配置 navigateToMiniProgramAppIdList,如下图: "navigateToMiniProgra ...
-
【小程序】微信小程序打开其他小程序(打开同一主体公众号下关联的另一个小程序)
微信小程序打开其他小程序(打开同一公众号下关联的另一个小程序) 注:只有同一(主体)公众号下的关联的小程序之间才可相互跳转 wx.navigateToMiniProgram(OBJECT) wx.n ...
随机推荐
-
python下	help()使用方法
查看python所有的modules:help("modules") 单看python所有的modules中包含指定字符串的modules: help("modules ...
-
python定时器爬取豆瓣音乐Top榜歌名
python定时器爬取豆瓣音乐Top榜歌名 作者:vpoet mail:vpoet_sir@163.com 注:这些小demo都是前段时间为了学python写的,现在贴出来纯粹是为了和大家分享一下 # ...
-
win8.1下安装ubuntu 14.0 4LTS
1.前奏 电脑上已经安装了win8.1系统 2.准备工作 关闭win8.1的快速启动 步骤: 控制面板->电源选项->选择电源按钮的功能->更改不可用的设置,然后把"启用快 ...
-
从GitHub下载demo时遇到的依赖问题
从GitHub上使用download zip下载时,经常遇到一些依赖工程没有一起下载,如果额外手动下载,配置起来也相当费事,其实,标准的方法是使用以下命令下载这样的demo. git clone -- ...
-
MySQL 复习笔记
本文内容 SQL 语句 创建数据库 创建数据表 数据完整性约束 四种基本字符类型说明 SQL 基本语句 类型转换函数 日期函数 数学函数 字符串函数 合并结果集 union CASE 函数用法 IF ...
-
Python 字符串转JSON; 先装字典在转JSON; json.dumps(d)
#-*- coding:UTF-8 -*- import os; import json class MysqlUtil(): def __init__(self): pass if __name__ ...
-
【干货】SIFT-Workstation 下载与安装 不跳过每一个细节部分
SIFT-Workstation.ova 下载地址https://digital-forensics.sans.org/community/download-sift-kit ov ...
-
windows多线程同步
概述 任何单个应用程序都不能完全使该处理器达到满负荷.当一个线程遇到较长等待时间事件时,同步多线程还允许另一线程中的指令使用所有执行单元.例如,当一个线程发生高速缓存不命中,另一个线程可以继续执行.同 ...
-
C++拾遗——重新开始
http://www.cnblogs.com/uniqueliu/category/307731.html
-
Web API(四):Web API参数绑定
在这篇文章中,我们将学习Web API如何将HTTP请求数据绑定到一个操作方法的参数中. 操作方法在Web API控制器中可以有一个或多个不同类型的参数.它可以是基本数据类型或复杂类型.Web API ...