<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多级数据读取的更多相关文章

  1. PHP读取XML文件数据

    XML文件 <?xml version="1.0" encoding="UTF-8"?> <node> <student> ...

  2. [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序读取相关数据

    这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译,这里是第七篇:为ASP.NET MVC应用程序 ...

  3. 第一周:读取XML深度数据并将其重建为三维点云

    本周主要任务:学习PCL点云库,掌握利用PCL对点云处理的方法 任务时间:2014年9月1日-2014年9月7日 任务完成情况:完成了读取单幅xml深度数据,并重建三维点云并显示 任务涉及基本方法: ...

  4. XML数据读取方式性能比较(一)

    原文:XML数据读取方式性能比较(一) 几个月来,疑被SOA,一直在和XML操作打交道,SQL差不多又忘光了.现在已经知道,至少有四种常用人XML数据操作方式(好像Java差不多),不过还没有实际比较 ...

  5. 为ASP.NET MVC应用程序读取相关数据

    为ASP.NET MVC应用程序读取相关数据 2014-05-08 18:24 by Bce, 299 阅读, 0 评论, 收藏, 编辑 这是微软官方教程Getting Started with En ...

  6. asp.net接收发送的xml字符串数据

    最近研究为新的接口,发现发送的消息的格式为xml类型.之前接口接触的多是接收json类型的数据,可以直接通过Request["Key"]/Request.QueryString[& ...

  7. spring 框架的xml文件如何读取properties文件数据

    spring 框架的xml文件如何读取properties文件数据 第一步:在spring配置文件中 注意:value可以多配置几个properties文件 <bean id="pro ...

  8. C# 递归读取XML菜单数据

    在博客园注册了有4年了,很遗憾至今仍未发表过博客,趁周末有空发表第一篇博客.小生不才,在此献丑了! 最近在研究一些关于C#的一些技术,纵观之前的开发项目的经验,做系统时显示系统菜单的功能总是喜欢把数据 ...

  9. C#读取xml节点数据方法小结

    本文实例总结了C#读取xml节点数据的方法.分享给大家供大家参考.具体如下: 第一种: 使用XPath XML的路径我配置在web.config 的appSettings节点下 <appSett ...

随机推荐

  1. MySQL-->基础-->001-->MySQL基本操作

    一.MySQL安装 卸载mysql 第一步 sudo apt-get autoremove --purge mysql-server-5.0 sudo apt-get remove mysql-ser ...

  2. mormot json操作

    使用JSon只需要引用一个文件synCommons. procedure TForm1.Button1Click(Sender: TObject);var jo: Variant; i: Int64; ...

  3. "2013":爱你不容易

    2013对我来说确实像年初时曾给自己定义的那样,真的是非常不平常的一年.依稀记得去年年终时,BOSS和我深聊了1多钟头,谈到职业规划.人生还有家庭的林林种种.春节在家时也仔细考虑过2013自己该如何规 ...

  4. 团队项目作业:利用NABCD模型进行竞争性需求分析

    NABC正是这样的一套框架,当你试图提出一项崭新的提案之际,它能够提供四个思维基点,令你的商业策划具备天马行空的基础. 具体来说,NABC是四个关键词的首字母缩写- Need(需求)-现在市场上未被满 ...

  5. pdflatex, xelatex, texstudio中文编码问题

    使用xelatex,源文件需要用utf-8编译,pdf文件不会乱码. 使用pdflatex,源文件不能使用utf-8编码,否则pdf文件会乱码. 使用GB2312没问题.

  6. 使用jQuery.form插件,实现完美的表单异步提交

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs ...

  7. oracle sql优化笔记

    oracle优化一般分为:1.sql优化(现在oracle都会根据sql语句先进行必要的优化处理,这种应该用户不大了,但是像关联和嵌套查询肯定是和影响性能的) A.oracle的sql语句的条件是从右 ...

  8. sql语句练习50题

    Student(Sid,Sname,Sage,Ssex) 学生表 Course(Cid,Cname,Tid) 课程表 SC(Sid,Cid,score) 成绩表 Teacher(Tid,Tname) ...

  9. CodeIgnitor 创建admin和其他目录,前后端分离,很巧妙的方式,网上查找其他的都不是使用这种方式实现的。

    在index.php的第97和98行的注释, // The directory name, relative to the "controllers" folder. Leave ...

  10. Python-pycharm

    进入博客园的第一篇随笔,作为一个编程菜鸟,最近在学习Python,为毕设做准备.总觉得Python自带的idle不太好用,一位“大鸟”向我推荐了pycharm,于是我就抱着试试看的态度下了一个,目前感 ...