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熟悉的话, 是不是发现简单了不少呢?