[英]C#: How to convert a list of objects to a list of a single property of that object?
Say I have:说我有:
IList<Person> people = new List<Person>();
And the person object has properties like FirstName, LastName, and Gender. person 对象具有 FirstName、LastName 和 Gender 等属性。
How can I convert this to a list of properties of the Person object.如何将其转换为 Person 对象的属性列表。 For example, to a list of first names.例如,到一个名字列表。
IList<string> firstNames = ???
List<string> firstNames = people.Select(person => person.FirstName).ToList();
并与排序
List<string> orderedNames = people.Select(person => person.FirstName).OrderBy(name => name).ToList();
IList<string> firstNames = (from person in people select person.FirstName).ToList();
要么
IList<string> firstNames = people.Select(person => person.FirstName).ToList();
firstNames = (from p in people select p=>p.firstName).ToList();
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace TestProject
{
public partial class WebForm3 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
SampleDataContext context = new SampleDataContext();
List<Employee> l = new List<Employee>();
var qry = from a in context.tbl_employees where a.Gender=="Female"
orderby a.Salary ascending
select new Employee() {
ID=a.Id,
Fname=a.FName,
Lname=a.Lname,
Gender=a.Gender,
Salary=a.Salary,
DepartmentId=a.DeparmentId
};
l= qry.ToList();
var e1 = from emp in context.tbl_employees
where emp.Gender == "Male"
orderby emp.Salary descending
select emp;
GridView1.DataSource = l;
GridView1.DataBind();
}
}
public class Employee
{
public Int64 ID { get; set; }
public String Fname { get; set; }
public String Lname { get; set; }
public String Gender { get; set; }
public decimal? Salary { get; set; }
public int? DepartmentId { get; set; }
}
}
using System.Collections.Generic;
using System.Linq;
IList<Person> people = new List<Person>();
IList<string> firstNames = people.Select(person => person.FirstName).ToList();
This will turn it to a list:这将把它变成一个列表:
List<string> firstNames = people.Select(person => person.FirstName).ToList();
This will return one (the first one):这将返回一个(第一个):
var firstname = people.select(e => e.firstname).FirstOrDefault();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.