LINQ方法获取List中两个索引之间的项目

时间:2013-01-21 08:45:27

标签: c# linq

我有Employee对象列表。我需要在两个索引之间只选择两个雇员对象(基于开始和结束变量)。以下代码工作正常但它不在LINQ中。为此目的,最好的LINQ代码是什么?

注意:我正在寻找Method Chain方法

CODE

public static class DatabaseSimulator
{

    public static List<Employee> GetData(string name, int index, int pageSize)
    {
        List<Employee> searchResult = new List<Employee>();
        List<Employee> employeesSource = SearchEmployees(name);

        int start = ((index - 1) * pageSize)  + 1;
        int end = (index * pageSize);
        for (int i = start; i <= end; i++)
        {
            if (searchResult != null)
            {
                int listCount = employeesSource.Count;
                for (int x = 0; x < listCount; x++)
                {
                    if (x == i)
                    {
                        searchResult.Add(employeesSource[x]);
                        break;
                    }
                }
            }
        }

        return searchResult;

    }


    private static List<Employee> SearchEmployees(string name)
    {
        List<Employee> employees = GetEmployees();
        return employees.Where(r => r.Name == name).ToList();
    }

    private static List<Employee> GetEmployees()
    {
        List<Employee> employees = new List<Employee>();
        int i = 0;
        for (i = 0; i <= 100; i++)
        {
            Employee emp = new Employee();
            emp.EmpID = i;
            if (i % 2 == 0)
            {
                emp.Name = "Divisible by 2";
            }
            else if  (i % 3 == 0)
            {
                emp.Name = "Divisible by 3";
            }
            else if (i % 5 == 0)
            {
                emp.Name = "Divisible by 5";
            }
            else if (i % 7 == 0)
            {
                emp.Name = "Divisible by 7";
            }
            else 
            {
                emp.Name = "Other -- "+ i.ToString();
            }

            employees.Add(emp);
        }

        return employees;
    }

}

客户端

List<Employee> searchResult = DatabaseSimulator.GetData("Divisible by 2", 2, 2);

1 个答案:

答案 0 :(得分:49)

您可以使用list.Skip(startIndex).Take(endIndex - startIndex)构建。

哪里

startIndex:是要选择的第一个项目的索引

endIndex:是要选择的 last 项目的索引

相关问题