c# LINQ 将数据集转换成XML
2011-09-05 17:12
183 查看
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml.Linq;
namespace mytest
{
public class Program
{
static void Main(string[] args)
{
List<Student> students = new List<Student>() {
new Student{First="Svetlana",Last="Omelchenko",ID=111,Street="123 Main Street",City="Seattle",Scores=new List<int>(){97, 92, 81, 60}},
new Student{First="Claire",Last="O’Donnell",ID=112,Street="124 Main Street",City="Redmond",Scores=new List<int>(){75, 84, 91, 39}},
new Student{First="Sven",Last="Mortensen",ID=113,Street="125 Main Street",City="Lake City",Scores= new List<int> {88, 94, 65, 91}},
};
List<Teacher> teachers = new List<Teacher>(){
new Teacher {First="Ann", Last="Beebe", ID=945, City = "Seattle"},
new Teacher {First="Alex", Last="Robinson", ID=956, City = "Redmond"},
new Teacher {First="Michiyo", Last="Sato", ID=972, City = "Tacoma"}
};
//用查询语法生成xml格式
var studentXML = new XElement("Root", from student in students
let x = String.Format("{0},{1},{2},{3}", student.Scores[0], student.Scores[1], student.Scores[2], student.Scores[3])
select new XElement("student",
new XElement("First", student.First),
new XElement("Last", student.Last),
new XElement("Scores", x)));
//用Lambda表达式(方法语法)生成xml格式
var teacherXML = new XElement("Root", teachers.Select(p => new XElement("Teacher", new XElement("First", p.First),
new XElement("Last", p.Last),
new XElement("Id", p.ID),
new XElement("City", p.City))));
Console.WriteLine("---------开始打印----------------------");
Console.WriteLine(studentXML);
Console.WriteLine("----------------------------------------");
Console.WriteLine(teacherXML);
Console.WriteLine("----------------------------------------");
foreach (var i in teacherXML.Nodes())
{
Console.WriteLine(i);//打印第一个节点子节点的集合
}
Console.WriteLine("--------------打印完成------------------");
Console.ReadKey();
}
}
class Student
{
public string First { get; set; }
public string Last { get; set; }
public int ID { get; set; }
public string Street { get; set; }
public string City { get; set; }
public List<int> Scores;
}
//***********************************************************************************************************
//Module:Teacher.cs
//Author:limeteor
//Create Date:2008-06-27
//***********************************************************************************************************
class Teacher
{
public string First { get; set; }
public string Last { get; set; }
public int ID { get; set; }
public string City { get; set; }
}
}
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml.Linq;
namespace mytest
{
public class Program
{
static void Main(string[] args)
{
List<Student> students = new List<Student>() {
new Student{First="Svetlana",Last="Omelchenko",ID=111,Street="123 Main Street",City="Seattle",Scores=new List<int>(){97, 92, 81, 60}},
new Student{First="Claire",Last="O’Donnell",ID=112,Street="124 Main Street",City="Redmond",Scores=new List<int>(){75, 84, 91, 39}},
new Student{First="Sven",Last="Mortensen",ID=113,Street="125 Main Street",City="Lake City",Scores= new List<int> {88, 94, 65, 91}},
};
List<Teacher> teachers = new List<Teacher>(){
new Teacher {First="Ann", Last="Beebe", ID=945, City = "Seattle"},
new Teacher {First="Alex", Last="Robinson", ID=956, City = "Redmond"},
new Teacher {First="Michiyo", Last="Sato", ID=972, City = "Tacoma"}
};
//用查询语法生成xml格式
var studentXML = new XElement("Root", from student in students
let x = String.Format("{0},{1},{2},{3}", student.Scores[0], student.Scores[1], student.Scores[2], student.Scores[3])
select new XElement("student",
new XElement("First", student.First),
new XElement("Last", student.Last),
new XElement("Scores", x)));
//用Lambda表达式(方法语法)生成xml格式
var teacherXML = new XElement("Root", teachers.Select(p => new XElement("Teacher", new XElement("First", p.First),
new XElement("Last", p.Last),
new XElement("Id", p.ID),
new XElement("City", p.City))));
Console.WriteLine("---------开始打印----------------------");
Console.WriteLine(studentXML);
Console.WriteLine("----------------------------------------");
Console.WriteLine(teacherXML);
Console.WriteLine("----------------------------------------");
foreach (var i in teacherXML.Nodes())
{
Console.WriteLine(i);//打印第一个节点子节点的集合
}
Console.WriteLine("--------------打印完成------------------");
Console.ReadKey();
}
}
class Student
{
public string First { get; set; }
public string Last { get; set; }
public int ID { get; set; }
public string Street { get; set; }
public string City { get; set; }
public List<int> Scores;
}
//***********************************************************************************************************
//Module:Teacher.cs
//Author:limeteor
//Create Date:2008-06-27
//***********************************************************************************************************
class Teacher
{
public string First { get; set; }
public string Last { get; set; }
public int ID { get; set; }
public string City { get; set; }
}
}
相关文章推荐
- xml to linq C#实例 类和xml文件互转换
- C#将LINQ数据集转换为Datatable
- C#中利用LINQ to XML与反射把任意类型的泛型集合转换成XML格式字符串的方法
- C#中利用LINQ to XML与反射把任意类型的泛型集合转换成XML格式字符串的方法
- C#中linq学习(将泛型集合转换为XML元素)示例
- C#中linq学习(将泛型集合转换为XML元素)示例
- 数据集转换成xml(C#代码)
- c# 将xml内容转换成DataSet
- C# Linq To XML 读取XML,修改属性
- 如何在ASP.NET中用C#将XML转换成JSON
- 如何在ASP.NET中用C#将XML转换成JSON
- C# XML与Json之间相互转换实例详解
- C# XML与Json之间相互转换实例详解
- C#操作Xml:linq to xml操作XML
- C#使用Linq操作Xml文件(创建xml文件、增删改查xml文件节点信息)的方法
- 如何使用 Visual Basic .NET 和 ASP.NET 将数据集转换为 Excel 的电子表格 XML
- c# XML和实体类之间相互转换(序列化和反序列化)
- 用C#把文件转换为XML
- C#基础精华06(Linq To XML,读取xml文件,写入xml)
- C#将Dictionary转换为XML