C# with XML(2)

Write a Winform application that can accept the user to enter Course name, corresponding Teacher’s name and TA’s name. Save the data into the XML. When the user enters a Teacher’s name or a TA’s name to search, the system should show all the courses he/she teaches.

  1. 首先设计一下 XML 存储格式
<?xml version="1.0" ?>
<data>
  <Course>
      <title> DataBase</title>
      <teacher lecturer="Jack" ta="Lucy" />
  </Course>
</data>
  1. 布局界面
界面布局效果

左边部分是 添加课程, 右边是根据人名搜索,并且显示在下方的listbox

  1. 代码部分

代码开头必须引用

// FOR XML 
using System.Xml;
using System.Xml.XPath;
using System.IO;

Form加载时候 初始化 XML 文件。

        private void Form1_Load(object sender, EventArgs e)
        {
            // 初始化 XML
            initXML();
        }

具体代码实现 initXML()。

        // initial XML 
        private void initXML()
        {
            if (!File.Exists("CourseData.xml")) {
                //如果不存在则 创建XML

                //构建XmlDocument 对象
                XmlDocument doc = new XmlDocument();
                //声明
                XmlDeclaration declare = doc.CreateXmlDeclaration("1.0", "utf-8", null);
                doc.AppendChild(declare);
                //创建一个根节点(一级)
                XmlElement root = doc.CreateElement("CourseData");
                doc.AppendChild(root);
                doc.Save("CourseData.xml");
            }


        }

用户点击添加课程按钮,将数据添加保存在XML文件内。

        // 用户点击添加按钮事件
        private void addBtn_Click(object sender, EventArgs e)
        {
            string course = courseTxtBox.Text.Trim();
            string lecturer = lecturerTxtBox.Text.Trim();
            string ta = taTxtBox.Text.Trim();

            if (course == "" || course == null || lecturer == "" || lecturer == null || ta == "" || ta == null)
            {
                MessageBox.Show("TextBox cannot be empty!");
            }
            else {
                // 调用 添加课程节点方法
                addCourseNode(course, lecturer,ta);
            }
            
        }

具体实现如何添加到 XML 的 addCourseNode(string course, string lecturer,string ta) 方法

        // 添加 Course 节点
        private void addCourseNode(string course, string lecturer,string ta) {
            //如果存在则 读取xml文件
            XmlDocument doc = new XmlDocument();
            doc.Load("CourseData.xml");

            //先获取到 CourseData 的节点(一级)
            XmlNode node = doc.SelectSingleNode("//CourseData");
            //变量
            //计算当前有多少childnodes
            int count = node.ChildNodes.Count + 1;
           
            //创建节点 Course(二级)
            XmlElement courseNode = doc.CreateElement("Course");

            //创建节点 title (三级)
            XmlElement titleNode = doc.CreateElement("title");
            // 插入 course title
            titleNode.InnerText = course;
            //创建节点  teacher(三级)
            XmlElement teacherNode = doc.CreateElement("teacher");
            // 添加 lecturer 属性 并且赋值
            teacherNode.SetAttribute("lecturer", lecturer);
            // 添加 ta 属性 并且赋值
            teacherNode.SetAttribute("ta", ta);
            // courseNode 添加 titleNode节点
            courseNode.AppendChild(titleNode);
            // courseNode 添加 teacherNode节点
            courseNode.AppendChild(teacherNode);
            // 父 节点 添加 courseNode 节点
            node.AppendChild(courseNode);
            // 保存
            doc.Save("CourseData.xml");
            //弹出消息框提示初始化完毕
            MessageBox.Show("添加成功!");
        }

点击 搜索按钮事件

         // 搜索按钮点击事件
        private void searchBtn_Click(object sender, EventArgs e)
        {
            // 清除 listBox 内容
            this.listBox1.Items.Clear();
            // 获取 搜索框的 内容
            string name = searchTxtBox.Text.Trim();
            if (name == "" || name == null)
            {
                MessageBox.Show("Staff's name  cannot be empty!");
            }
            else {
                //找到目标地方 (两个 一个 lecturer 一个 ta)
                string lecturer = "//teacher[@lecturer='" + name + "']";
                string ta = "//teacher[@ta='" + name + "']";
                //读取 XML 
                XmlDocument doc = new XmlDocument();
                doc.Load("CourseData.xml");
                // 临时变量存储 course title
                string temp;
                // 获取 lecturer 所有节点 ( 用户输入的查询的 名字 )
                XmlNodeList nodes = doc.SelectNodes(lecturer);
                foreach (XmlNode node in nodes) {
                    // 先找到父节点
                    XmlNode parent = node.ParentNode;
                    // 再找到子节点 的第一个,并且获取到 文本
                    temp = parent.ChildNodes[0].InnerText;
                    // 添加到 listBox
                    this.listBox1.Items.Add(temp);
                }

                // 获取 ta 所有节点 ( 用户输入的查询的 名字 )
                nodes = doc.SelectNodes(ta);
                foreach (XmlNode node in nodes)
                {
                    // 先找到父节点
                    XmlNode parent = node.ParentNode;
                    // 再找到子节点 的第一个,并且获取到 文本
                    temp = parent.ChildNodes[0].InnerText;
                    // 添加到 listBox
                    this.listBox1.Items.Add(temp);
                }
                if (nodes.Count == 0) {
                    MessageBox.Show("Cannot Found");
                }
            }
        }

所有 Form.cs 代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

// FOR XML 
using System.Xml;
using System.Xml.XPath;
using System.IO;


namespace XMLDemo2
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            // 初始化 XML
            initXML();
        }


        // initial XML 
        private void initXML()
        {
            if (!File.Exists("CourseData.xml")) {
                //如果不存在则 创建XML

                //构建XmlDocument 对象
                XmlDocument doc = new XmlDocument();
                //声明
                XmlDeclaration declare = doc.CreateXmlDeclaration("1.0", "utf-8", null);
                doc.AppendChild(declare);
                //创建一个根节点(一级)
                XmlElement root = doc.CreateElement("CourseData");
                doc.AppendChild(root);
                doc.Save("CourseData.xml");
            }


        }


        // 用户点击添加按钮事件
        private void addBtn_Click(object sender, EventArgs e)
        {
            string course = courseTxtBox.Text.Trim();
            string lecturer = lecturerTxtBox.Text.Trim();
            string ta = taTxtBox.Text.Trim();

            if (course == "" || course == null || lecturer == "" || lecturer == null || ta == "" || ta == null)
            {
                MessageBox.Show("TextBox cannot be empty!");
            }
            else {
                // 调用 添加课程节点方法
                addCourseNode(course, lecturer,ta);
            }
            
        }


        // 添加 Course 节点
        private void addCourseNode(string course, string lecturer,string ta) {
            //如果存在则 读取xml文件
            XmlDocument doc = new XmlDocument();
            doc.Load("CourseData.xml");

            //先获取到 CourseData 的节点(一级)
            XmlNode node = doc.SelectSingleNode("//CourseData");
            //变量
            //计算当前有多少childnodes
            int count = node.ChildNodes.Count + 1;
           
            //创建节点 Course(二级)
            XmlElement courseNode = doc.CreateElement("Course");

            //创建节点 title (三级)
            XmlElement titleNode = doc.CreateElement("title");
            // 插入 course title
            titleNode.InnerText = course;
            //创建节点  teacher(三级)
            XmlElement teacherNode = doc.CreateElement("teacher");
            // 添加 lecturer 属性 并且赋值
            teacherNode.SetAttribute("lecturer", lecturer);
            // 添加 ta 属性 并且赋值
            teacherNode.SetAttribute("ta", ta);
            // courseNode 添加 titleNode节点
            courseNode.AppendChild(titleNode);
            // courseNode 添加 teacherNode节点
            courseNode.AppendChild(teacherNode);
            // 父 节点 添加 courseNode 节点
            node.AppendChild(courseNode);
            // 保存
            doc.Save("CourseData.xml");
            //弹出消息框提示初始化完毕
            MessageBox.Show("添加成功!");
        }

        // 搜索按钮点击事件
        private void searchBtn_Click(object sender, EventArgs e)
        {
            // 清除 listBox 内容
            this.listBox1.Items.Clear();
            // 获取 搜索框的 内容
            string name = searchTxtBox.Text.Trim();
            if (name == "" || name == null)
            {
                MessageBox.Show("Staff's name  cannot be empty!");

            }
            else {
                //找到目标地方 (两个 一个 lecturer 一个 ta)
                string lecturer = "//teacher[@lecturer='" + name + "']";
                string ta = "//teacher[@ta='" + name + "']";
                //读取 XML 
                XmlDocument doc = new XmlDocument();
                doc.Load("CourseData.xml");
                // 临时变量存储 course title
                string temp;
                // 获取 lecturer 所有节点 ( 用户输入的查询的 名字 )
                XmlNodeList nodes = doc.SelectNodes(lecturer);
                foreach (XmlNode node in nodes) {
                    // 先找到父节点
                    XmlNode parent = node.ParentNode;
                    // 再找到子节点 的第一个,并且获取到 文本
                    temp = parent.ChildNodes[0].InnerText;
                    // 添加到 listBox
                    this.listBox1.Items.Add(temp);
                }

                // 获取 ta 所有节点 ( 用户输入的查询的 名字 )
                nodes = doc.SelectNodes(ta);
                foreach (XmlNode node in nodes)
                {
                    // 先找到父节点
                    XmlNode parent = node.ParentNode;
                    // 再找到子节点 的第一个,并且获取到 文本
                    temp = parent.ChildNodes[0].InnerText;
                    // 添加到 listBox
                    this.listBox1.Items.Add(temp);

                }
                if (nodes.Count == 0) {
                    MessageBox.Show("Cannot Found");
                }
            }
        }
    }
    
    
}


  1. 运行效果
添加课程

XML 文件保存在于 项目文件夹/bin/Debug 或者 项目文件夹/bin/Release


XML内容

多添加几门课数据量

多添加一些数据

查询结果 : Maggie

Maggie

查询结果 : hejing

hejing
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,451评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,172评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,782评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,709评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,733评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,578评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,320评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,241评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,686评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,878评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,992评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,715评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,336评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,912评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,040评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,173评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,947评论 2 355

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,657评论 18 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,632评论 18 399
  • **2014真题Directions:Read the following text. Choose the be...
    又是夜半惊坐起阅读 9,505评论 0 23
  • 我知道秋天是怎么来的 菊花开了 叶尖黄了 我打响了第一个喷嚏 夜里能看见孤零零的萤火虫 电话那头的老妈又开始念叨起...
    Melonmelonmelon阅读 976评论 8 29
  • 早上在拥挤的地铁里,耳机里单曲循环着“另一个天堂”,环绕的音乐依然隔绝不了车厢中嘈杂的争论与不满的嘟囔。不同...
    加青贝贝阅读 246评论 0 3