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>


因爲習慣的關係,因此喜歡把數據存成一行的格式,一目瞭然。html

對於多行的格式有點排斥,若是數據少還好,若是多了一頁就只能看到幾條數據。node

或則來我的告訴我那樣的格式有比這種好的地方(純討論)app


以上是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的格式。code


 

        /// <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

若是在已知Xml結構的狀況下那麼能夠直接找到相對應的節點下的數據。htm


 

        /// <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;
        }

 

 

 

其實代碼就這些了,但爲了拼出這些代碼可費了我很多時間。 字符串

相關文章
相關標籤/搜索