Linq to XML同样是对原C#访问XML文件的方法的封装,简化了用xpath进行xml的查询以及增加,修改,删除xml元素的操作。
C#访问XML文件的常用类:XmlDocument,XmlElement,XmlAttribute,XmlNode,XmlText等;

Linq to XML 中的常用类 :XDocument,XElement,XAttribute。 废话不多说了,直接上代码: xml文件数据格式如下

public class DataBaseInfo

{

public string ID { get; set; }

public string Company { get; set; }

public string Server { get; set; }

public string DataBase { get; set; }

public string UserName { get; set; }

public string Password { get; set; }

private static XDocument doc = new XDocument();

public static string filePath = ".\\DataBaseInfo.xml";

public DataBaseInfo() {

doc = XDocument.Load(filePath);

}

public DataBaseInfo(string filepath):this()

{

filePath = filepath;

}

/// <summary>

/// 增

/// </summary>

/// <returns></returns>

public  bool Add()

{

XElement db = new XElement("DataBase",

new XAttribute("id", ID),

new XElement("company", new XAttribute("value",Company)),

new XElement("server", new XAttribute("value",Server)),

new XElement("database", new XAttribute("value",DataBase)),

new XElement("username", new XAttribute("value",UserName)),

new XElement("password", new XAttribute("value", Password))

);

try

{

//用XElement的Add方法

//XElement doc = XElement.Load(filePath);

//doc.Add(db);

//用XDocument的Add方法

doc.Element("DataBases").Add(db);

doc.Save(filePath);

return true;

}

catch

{

return false;

}

}

/// <summary>

/// 删

/// </summary>

/// <param name="id"></param>

/// <returns></returns>

public static bool Remove(string id)

{

XElement xe = (from db in doc.Element("DataBases").Elements("DataBase") where db.Attribute("id").Value == id select db).Single() as XElement;

try

{

xe.Remove();

doc.Save(filePath);

return true;

}

catch

{

return false;

}

}

/// <summary>

/// 改

/// </summary>

/// <returns></returns>

public bool Modify()

{

XElement xe = (from db in doc.Element("DataBases").Elements("DataBase") where db.Attribute("id").Value.ToString() == ID select db).Single();

try

{

xe.Element("company").Attribute("value").Value = Company;

xe.Element("server").Attribute("value").Value = Server;

xe.Element("database").Attribute("value").Value = DataBase;

xe.Element("username").Attribute("value").Value = UserName;

xe.Element("password").Attribute("value").Value = Password;

doc.Save(filePath);

return true;

}

catch

{

return false;

}

}

/// <summary>

/// 查

/// </summary>

/// <returns></returns>

public List<DataBaseInfo> GetAll()

{

List<DataBaseInfo> dbs = (from db in doc.Element("DataBases").Elements("DataBase")

select new DataBaseInfo

{

ID = db.Attribute("id").Value.ToString(),

Company = db.Element("company").Attribute("value").Value.ToString(),

Server = db.Element("server").Attribute("value").Value.ToString(),

DataBase = db.Element("database").Attribute("value").Value.ToString(),

UserName = db.Element("username").Attribute("value").Value.ToString(),

Password = db.Element("password").Attribute("value").Value.ToString()

}).ToList();

return dbs;

}

怎么样,如何对之前DOM方式访问XML熟悉的话, 是不是发现简单了不少呢?

最新文章

  1. 在Dell R720服务器上安装ESXI5.5时会出现卡在LSI_MR3.V00的解决方法
  2. ubuntu 14.04 compiz的ALT + TAB切换程序
  3. [译]学习IPython进行交互式计算和数据可视化(七)
  4. 烂泥:学习ubuntu之快速搭建LNMP环境
  5. java基础学习总结——基础语法1
  6. Html-Css-设置DIV边框圆滑
  7. UI 网络程序
  8. HDU 5047
  9. object在ie8与ie9中与下文多出几像素问题
  10. UITableView 表视图编辑
  11. Hadoop集群(第7期)_Eclipse开发环境设置
  12. BZOJ2440(全然平方数)二分+莫比乌斯容斥
  13. 【Mac】-NO.133.Mac.1 -【重置忘记macos root密码】
  14. python----函数的动态传参
  15. async+await一起使用
  16. HyperLedger/Fabric JAVA-SDK with 1.1
  17. truffle框架快速开发合约步骤
  18. P4035 [JSOI2008]球形空间产生器
  19. Java集合的遍历方式
  20. Netty(RPC高性能之道)原理剖析

热门文章

  1. oracle单行函数 之 时间函数
  2. P2257 YY的GCD(莫比乌斯反演)
  3. 【C#】委托的发展
  4. js实现类型jq的dom加载完成
  5. FICO年终完全手册
  6. 20165306 实验一Java开发环境的熟悉
  7. 线性判别分析(Linear Discriminant Analysis-LDA)
  8. _event_phase
  9. Add Two Numbers ,使用链表参数
  10. Mongodb 创建管理员帐号与普通帐号