net对XML增删改查
Pass:看公司代码,配置下拉框的功能,和下拉框的数字转文字。配置xml里面有下拉的value,name,这样界面直接显示数字,然后转译成中文
1.xml文件格式
<?xml version="1.0" encoding="utf-8"?>
<bookstore>
<book category="COOKING" id="">
<title lang="en">Everyday Italian</title>
<author>Giada De Laurentiis</author>
<year></year>
<price></price>
</book>
</bookstore>
2.认识xml的基本操作的几个基本概念
net操作xml有基本的XMLDocument、linq
2.1 XmlDocument : XmlDocument将XML视为树状结构,它装载XML文档,并在内存中构建该文档的树状结构。下面来看下XmlDocument提供了哪些功能。
2.2 XmlNode:节点
2.3 XmlElement:元素
2.4几个基本操作
获取节点的值:?.InnerText ;
获取节点的属性:?.Attributes["id"].InnerText ;
3.xml的增删改查
3.1 最基本
public book getModel()
{
//封装获取数据
book b = new book();
b.author = HttpContext.Current.Request["author"];
b.category = HttpContext.Current.Request["category"];
b.lang = HttpContext.Current.Request["lang"];
b.price = Convert.ToDouble(HttpContext.Current.Request["price"]);
b.title = HttpContext.Current.Request["title"];
b.year = Convert.ToInt16(HttpContext.Current.Request["year"]);
return b;
}
public List<book> readXMl()
{
List<book> ls = new List<book> { }; //1.载入xml
XmlDocument doc = new XmlDocument();
doc.Load(xmlPath); //2.获取文档下第一个子类的所以子类
XmlNodeList listNode = doc.SelectSingleNode("bookstore").ChildNodes; //3.遍历子类
foreach (XmlNode books in listNode)
{
book b = new book();
b.Id = Convert.ToInt16(books.Attributes["id"].InnerText);
b.category = books.Attributes["category"].InnerText;
b.title = books["title"].InnerText;
b.lang = books["title"].Attributes["lang"].InnerText;
b.author = books["author"].InnerText;
b.year = Convert.ToInt16(books["year"].InnerText);
b.price = Convert.ToDouble(books["price"].InnerText); ls.Add(b);
} return ls;
}
public book readXMLById()
{
book b = getModel(); //需要查询数据的Id
b.Id = Convert.ToInt16(HttpContext.Current.Request["id"]); XmlDocument root = new XmlDocument();
root.Load(xmlPath); XmlNode xml = root.SelectSingleNode("bookstore");
XmlNodeList listnode = xml.ChildNodes; //遍历bookstore下的节点
foreach (XmlNode i in listnode)
{
//获取每一个book的属性Id对比是否=需要查询的值
if (i.Attributes["id"].InnerText == b.Id.ToString())
{
b.category = i.Attributes[].InnerText;
b.title = i["title"].InnerText;
b.lang = i["title"].Attributes["lang"].InnerText;
b.author = i["author"].InnerText;
b.year = Convert.ToInt16(i["year"].InnerText);
b.price = Convert.ToDouble(i["price"].InnerText);
}
} return b; }
public bool WriteXml()
{
bool isValue = false;
try
{
//设置模型类,只是为了更好的看到数据
book b = getModel(); //创建xml文件
XmlDocument xml = new XmlDocument();
xml.Load(xmlPath); //最高级树
XmlNode root = xml.SelectSingleNode("bookstore");
int id = Convert.ToInt16(root.LastChild.Attributes["id"].InnerText) + ; //二级子节点
XmlElement node = xml.CreateElement("book");
node.SetAttribute("category", b.category);
node.SetAttribute("id", id.ToString()); //三级子节点
XmlElement n1 = xml.CreateElement("title");
n1.SetAttribute("lang", b.lang);
n1.InnerText = b.title; XmlElement n2 = xml.CreateElement("author");
n2.InnerText = b.author; XmlElement n3 = xml.CreateElement("year");
n3.InnerText = b.year.ToString(); XmlElement n4 = xml.CreateElement("price");
n4.InnerText = b.price.ToString(); //三级添加到二级
node.AppendChild(n1);
node.AppendChild(n2);
node.AppendChild(n3);
node.AppendChild(n4); //二级添加到一级
root.AppendChild(node); //把文件保存到路径
xml.Save(xmlPath);
isValue = true;
}
catch (Exception e)
{
HttpContext.Current.Response.Write(e);
}
return isValue; }
public bool delXMLById()
{
bool isValue = false;
book b = getModel();
b.Id = Convert.ToInt16(HttpContext.Current.Request["id"]);
//以上为获取数据 XmlDocument root = new XmlDocument();
root.Load(xmlPath); XmlNode xml = root.SelectSingleNode("bookstore");
XmlNodeList listnode = xml.ChildNodes;
foreach (XmlNode i in listnode)
{
if (i.Attributes["id"].InnerText.ToString() == b.Id.ToString())
{
xml.RemoveChild(i);
root.Save(xmlPath);
isValue = true;
}
} return isValue;
}
public bool upXMLByModel()
{
book b = getModel();
bool isValue = false;
b.Id = Convert.ToInt16(HttpContext.Current.Request["id"]);
//以上为获取数据:request[""] XmlDocument root = new XmlDocument();
root.Load(xmlPath);
XmlNode xml = root.SelectSingleNode("bookstore");
XmlNodeList xs = xml.ChildNodes; foreach (XmlNode x in xs)
{
if (x.Attributes["id"].InnerText.ToString() == b.Id.ToString())
{
XmlElement node = x as XmlElement;
node.SetAttribute("category", b.category); //三级树
XmlElement n1 = node.SelectSingleNode("title") as XmlElement;
n1.SetAttribute("lang", b.lang);
n1.InnerText = b.title; XmlElement n2 = node.SelectSingleNode("author") as XmlElement;
n2.InnerText = b.author; XmlElement n3 = node.SelectSingleNode("year") as XmlElement;
n3.InnerText = b.year.ToString(); XmlElement n4 = node.SelectSingleNode("price") as XmlElement;
n4.InnerText = b.price.ToString(); root.Save(xmlPath);
isValue = true;
}
}
return isValue;
}
3.2 linq操作
4.代码包
http://pan.baidu.com/s/1b6ReEU
net对XML增删改查的更多相关文章
- 使用python操作XML增删改查
使用python操作XML增删改查 什么是XML? XML 指可扩展标记语言(EXtensible Markup Language) XML 是一种标记语言,很类似 HTML XML 的设计宗旨是传输 ...
- [原创]Linq to xml增删改查Linq 入门篇:分分钟带你遨游Linq to xml的世界
本文原始作者博客 http://www.cnblogs.com/toutou Linq 入门篇(一):分分钟带你遨游linq to xml的世界 本文原创来自博客园 请叫我头头哥的博客, 请尊重版权, ...
- .net xml 增删改查基础复习及干货分享
今天做做项目时,有一个需求需要用到一些固定的文本数据,觉得将这些需要存储的信息直接写在代码里很不友好,放在数据库中存储又觉得不够方便,自然就想到了使用xml来进行操作,我平常在项目中其实用到xml的机 ...
- c# XML增删改查
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- Linq to XML 增删改查
Linq to XML同样是对原C#访问XML文件的方法的封装,简化了用xpath进行xml的查询以及增加,修改,删除xml元素的操作.C#访问XML文件的常用类:XmlDocument,XmlEle ...
- XML 增删改查
<?php $xmlpatch = 'index.xml'; $_id = '; $_title = 'title1'; $_content = 'content1'; $_author = ' ...
- c#操作xml增删改查
1.首先新建一个xml文件(Root是我写上的) 2. 3.直接上代码,更直观 (1)初始化xml /// <summary> /// 初始化xml /// </summary> ...
- Linq To Xml操作XML增删改查
对XML文件的操作在平时项目中经常要运用到,比如用于存放一些配置相关的内容:本文将简单运用Linq TO Xml对XML进行操作,主要讲解对XML的创建.加载.增加.查询.修改以及删除:重点在于类XD ...
- 4.Linq To Xml操作XML增删改查
转自https://www.cnblogs.com/wujy/p/3366812.html 对XML文件的操作在平时项目中经常要运用到,比如用于存放一些配置相关的内容:本文将简单运用Linq TO X ...
随机推荐
- Android无线调试
方法一: 1. 使用USB数据线连接设备. 2. 命令输入adb tcpip 5555 ( 5555为端口号,可以自由指定). 3. 断开 USB数据,此时可以连接你需要连接的|USB设备. 4. 再 ...
- [转]Android逆向之动态调试总结
一.在SO中关键函数上下断点 刚学逆向调试时.大多都满足于在SO中某关键函数上下断点.然后通过操作应用程序,去触发这个断点,然后进行调试 详细的步骤可以参见非虫大大的<Android软件安全与逆 ...
- 【代码笔记】iOS-缓存路径操作类
一,代码. AppDelegate.h #import <UIKit/UIKit.h> @interface AppDelegate : UIResponder <UIApplica ...
- Learn how to Use UIPageViewController in iOS
下面学习内容来自国外的IOS学习网站:The AppGuruz: UIPageViewController in iOS 也许需要FQ哦 认真做一遍上面入门UIPageController的教程,然 ...
- 学习Coding-iOS开源项目日志(三)
继续前两篇,接着本第三篇<学习Coding-iOS开源项目日志(三)>讲解Coding-iOS开源项目. 前 言:作为初级程序员,想要提高自己的水平,其中一个有效的学习方法就是学习别人好的 ...
- IOS设计模式-组合设计模式
前言:本篇博文将让你学会软件开发中的"何为树形结构"."何为组合模式"."组合模式可以解决的问题"等相关知识. 内容大纲: 1.树形结构 2 ...
- DB2LOOK命令提取数据库对象信息
提取复制数据库的DDL语句:db2look -d BCDLJS -e -o db2look.sql -a -a:导出所有用户的DDL-o: 定向结果到文件-d: 数据库名-e: 抽取复制数据库所需的 ...
- 解析ABP框架中的事务处理和工作单元,ABP事务处理
通用连接和事务管理方法连接和事务管理是使用数据库的应用程序最重要的概念之一.当你开启一个数据库连接,什么时候开始事务,如何释放连接...诸如此类的. 正如大家都知道的,.Net使用连接池(connec ...
- 记一次ORACLE的UNDO表空间爆满分析过程
这篇文章是记录一次ORACLE数据库UNDO表空间爆满的分析过程,主要整理.梳理了同事分析的思路.具体过程如下所示: 早上收到一数据库服务器的UNDO表空间的告警邮件,最早一封是7:55发出的(监控作 ...
- SQL语句查询某表的所有字段及数据类型
SQL语句查询某表的所有字段及数据类型 SELECT name AS column_name , TYPE_NAME(system_type_id) AS column_type , max_leng ...