C#/ASP.NET Xml多级数据读取
<Data>
<Project>
<Item Id="51351132-59a7-4c0b-909d-51b89b1c3159" IsDefault="1" Path="D:\TDDOWNLOAD\Source\Report1.App" />
<Item Id="e6fd198a-753e-42e5-a16c-e20450362795" IsDefault="1" Path="D:\TDDOWNLOAD\Source\Report2.App" />
</Project>
<AppSettings>
<Item Key="conn" Value="Data Source=192.168.2.227;Initial Catalog=master;User ID=sa;pwd=sa" />
</AppSettings>
</Data>
由于习惯的关系,所以喜欢把数据存成一行的格式,一目了然。
对于多行的格式有点排斥,如果数据少还好,如果多了一页就只能看到几条数据。
或则来个人告诉我那样的格式有比这种好的地方(纯讨论)
以上是Xml的数据格式,这里也顺便提下多级的新增方式。
/// <summary>
/// 新增一条地址数据
/// </summary>
/// <param name="entity">项目地址信息</param>
public void Create(Project entity)
{
//新增一条日志记录
var xmlDoc = new XmlDocument();
xmlDoc.Load(FileName);
var data = xmlDoc.SelectSingleNode("Data");//找到根节点 var project = data.SelectSingleNode("Project");//找到子节点 Project
var item = xmlDoc.CreateElement("Item");//创建子节点 Item item.SetAttribute("Id", entity.Id);
item.SetAttribute("IsDefault", entity.IsDefault);
item.SetAttribute("Path", entity.Path); project.AppendChild(item);//子项添加到 Project 节点中
data.AppendChild(project);
xmlDoc.Save(FileName);//保存
}
当然新增的前提是Xml格式已经存在了。
下面则是创建文件和Xml的格式。
/// <summary>
/// 文件夹或文件不存在则创建
/// </summary>
private void CreateFile()
{
var directoryInfo = new DirectoryInfo(FolderPath);//获取文件路径信息 if (!directoryInfo.Exists) directoryInfo.Create();//如果文件夹不存在 if (!File.Exists(FileName))
{
#region 创建默认Xml数据 //如果文件不存在则创建
File.Create(FileName).Close(); var xmlDoc = new XmlDocument();
var data = xmlDoc.CreateElement("Data");//创建根节点 var appSettings = xmlDoc.CreateElement("AppSettings");//连接字符串 节点
var project = xmlDoc.CreateElement("Project");//项目地址 节点
data.AppendChild(appSettings);
data.AppendChild(project); xmlDoc.AppendChild(data);
xmlDoc.Save(FileName);//保存 #endregion
}
}
这里可以新增几条数据待会儿用来测试读取
如果在已知Xml结构的情况下那么可以直接找到相对应的节点下的数据。
/// <summary>
/// 获取所有项目地址数据
/// </summary>
/// <returns></returns>
public IList<Project> GetAllProject()
{
var list = new List<Project>(); var xmlDoc = new XmlDocument();
xmlDoc.Load(FileName);
var xmlList = xmlDoc.SelectSingleNode("Data/Project").ChildNodes; foreach (XmlNode node in xmlList)
{
var entity = new Project
{
Id = node.Attributes["Id"].Value,
IsDefault = node.Attributes["IsDefault"].Value,
Path = node.Attributes["Path"].Value,
};
list.Add(entity);
}
return list;
}
其实代码就这些了,但为了拼出这些代码可费了我不少时间。
C#/ASP.NET Xml多级数据读取的更多相关文章
- PHP读取XML文件数据
XML文件 <?xml version="1.0" encoding="UTF-8"?> <node> <student> ...
- [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序读取相关数据
这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译,这里是第七篇:为ASP.NET MVC应用程序 ...
- 第一周:读取XML深度数据并将其重建为三维点云
本周主要任务:学习PCL点云库,掌握利用PCL对点云处理的方法 任务时间:2014年9月1日-2014年9月7日 任务完成情况:完成了读取单幅xml深度数据,并重建三维点云并显示 任务涉及基本方法: ...
- XML数据读取方式性能比较(一)
原文:XML数据读取方式性能比较(一) 几个月来,疑被SOA,一直在和XML操作打交道,SQL差不多又忘光了.现在已经知道,至少有四种常用人XML数据操作方式(好像Java差不多),不过还没有实际比较 ...
- 为ASP.NET MVC应用程序读取相关数据
为ASP.NET MVC应用程序读取相关数据 2014-05-08 18:24 by Bce, 299 阅读, 0 评论, 收藏, 编辑 这是微软官方教程Getting Started with En ...
- asp.net接收发送的xml字符串数据
最近研究为新的接口,发现发送的消息的格式为xml类型.之前接口接触的多是接收json类型的数据,可以直接通过Request["Key"]/Request.QueryString[& ...
- spring 框架的xml文件如何读取properties文件数据
spring 框架的xml文件如何读取properties文件数据 第一步:在spring配置文件中 注意:value可以多配置几个properties文件 <bean id="pro ...
- C# 递归读取XML菜单数据
在博客园注册了有4年了,很遗憾至今仍未发表过博客,趁周末有空发表第一篇博客.小生不才,在此献丑了! 最近在研究一些关于C#的一些技术,纵观之前的开发项目的经验,做系统时显示系统菜单的功能总是喜欢把数据 ...
- C#读取xml节点数据方法小结
本文实例总结了C#读取xml节点数据的方法.分享给大家供大家参考.具体如下: 第一种: 使用XPath XML的路径我配置在web.config 的appSettings节点下 <appSett ...
随机推荐
- MySQL-->基础-->001-->MySQL基本操作
一.MySQL安装 卸载mysql 第一步 sudo apt-get autoremove --purge mysql-server-5.0 sudo apt-get remove mysql-ser ...
- mormot json操作
使用JSon只需要引用一个文件synCommons. procedure TForm1.Button1Click(Sender: TObject);var jo: Variant; i: Int64; ...
- "2013":爱你不容易
2013对我来说确实像年初时曾给自己定义的那样,真的是非常不平常的一年.依稀记得去年年终时,BOSS和我深聊了1多钟头,谈到职业规划.人生还有家庭的林林种种.春节在家时也仔细考虑过2013自己该如何规 ...
- 团队项目作业:利用NABCD模型进行竞争性需求分析
NABC正是这样的一套框架,当你试图提出一项崭新的提案之际,它能够提供四个思维基点,令你的商业策划具备天马行空的基础. 具体来说,NABC是四个关键词的首字母缩写- Need(需求)-现在市场上未被满 ...
- pdflatex, xelatex, texstudio中文编码问题
使用xelatex,源文件需要用utf-8编译,pdf文件不会乱码. 使用pdflatex,源文件不能使用utf-8编码,否则pdf文件会乱码. 使用GB2312没问题.
- 使用jQuery.form插件,实现完美的表单异步提交
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs ...
- oracle sql优化笔记
oracle优化一般分为:1.sql优化(现在oracle都会根据sql语句先进行必要的优化处理,这种应该用户不大了,但是像关联和嵌套查询肯定是和影响性能的) A.oracle的sql语句的条件是从右 ...
- sql语句练习50题
Student(Sid,Sname,Sage,Ssex) 学生表 Course(Cid,Cname,Tid) 课程表 SC(Sid,Cid,score) 成绩表 Teacher(Tid,Tname) ...
- CodeIgnitor 创建admin和其他目录,前后端分离,很巧妙的方式,网上查找其他的都不是使用这种方式实现的。
在index.php的第97和98行的注释, // The directory name, relative to the "controllers" folder. Leave ...
- Python-pycharm
进入博客园的第一篇随笔,作为一个编程菜鸟,最近在学习Python,为毕设做准备.总觉得Python自带的idle不太好用,一位“大鸟”向我推荐了pycharm,于是我就抱着试试看的态度下了一个,目前感 ...