我当前的C#作业分配要求使用7条员工记录的预定义数组,每条记录由一组属性组成。这些记录必须使用foreach循环从数组中拉出所有员工记录,然后使用ToString的公共替代来显示具有特定列格式的记录。我已经能够毫无问题地实施此阶段。
然后,下一组要求希望我们仅显示服务时间少于一年或1至5年的员工记录,这就是我遇到的问题。
我们需要使用此类来表示当前日期(从作业中复制和粘贴):
public static class GlobalVars
{
public static DateTime reportDate = DateTime.Parse("02/28/2017");
}
我们还需要创建一个名为YearsOfService的原始方法来计算员工的服务年限,该方法将员工hirdDate年与GlobalVars类中当前日期的年进行比较。在这里完成:
public int YearsOfService()
{
DateTime current = GlobalVars.reportDate;
int yearsOfService = current.Year - hireDate.Year;
return yearsOfService;
}
我们需要使用以下语法在屏幕上打印记录(从作业复制和粘贴):
Employee emp = new Employee();
Employee[] employees = Employee.GetEmployeeData();
Console.WriteLine(Employee.EmployeeReportTitle("Employee Report Data Dump"));
Console.WriteLine(Employee.ColumnHeader());
foreach (Employee employee in employees)
{
Console.WriteLine(employee.ToString());
}
这是我格式化的覆盖字符串输出,用于列格式化:
public override string ToString()
{
return String.Format("{0,-10:D5} {1, -20}{2, -16}${3, -11}{4:MM/dd/yyyy} {5, 16:D2}",
empNumber, empName, empStatus, hourlyWage, hireDate, YearsOfService());
}
这可以很好地打印数组中的每个记录,但是如何在foreach级别插入需求?我需要实现一个筛选器,以便仅通过ToString打印的记录是yearsOfService高于特定值或在两个值之间的记录。
我已经尝试过if / else循环和切换大小写,但是我无法以排除/包含正确记录的方式来构造语法。
答案 0 :(得分:0)
您可以通过以下两种方式之一进行操作...
var minYoS = 3;
var maxYoS = 5;
foreach (Employee employee in employees.Where(x => x.YearsOfService() >= minYoS && x.YearsOfService() <= maxYoS))
{
Console.WriteLine(employee.ToString());
}
或
var minYoS = 3;
var maxYoS = 5;
foreach (Employee employee in employees)
{
if(minYoS <= employee.YearsOfService() && maxYoS >= employee.YearsOfService()){
Console.WriteLine(employee.ToString());
}
}
第一个示例使用LINQ投影仅对满足指定要求的员工进行迭代。第二个遍历所有员工,然后在foreach循环中,代码评估是否应将员工记录打印到控制台上
答案 1 :(得分:0)
您的过滤器可能是Where
方法,这是LINQ系列中最有用的方法。
ffmpeg