Я выяснил, в чем проблема, я добавляю 2 ICollection<RequestTracking>
в Employee
public class Employee
{
public int Id { get; set; }
public string FirstName { get; set; }
public string MiddleName { get; set; }
public string LastName { get; set; }
public DateTime Birthdate { get; set; }
public Gender Gender { get; set; }
public AppUser User { get; set; }
public ICollection<EmployeeStatus> EmployeesStatus { get; set; }
public ICollection<Resignation> Resignations { get; set; }
public ICollection<RequestTracking> RequestTrackingsFrom { get; set; }
public ICollection<RequestTracking> RequestTrackingsTo { get; set; }
}
Это - то, что я закончил тем, что делал:
static int GetMonth(int Year, int Week)
{
DateTime tDt = new DateTime(Year, 1, 1);
tDt.AddDays((Week - 1) * 7);
for (int i = 0; i <= 365; ++i)
{
int tWeek = CultureInfo.CurrentCulture.Calendar.GetWeekOfYear(
tDt,
CalendarWeekRule.FirstDay,
DayOfWeek.Monday);
if (tWeek == Week)
return tDt.Month;
tDt = tDt.AddDays(1);
}
return 0;
}
Я предпочел бы что-то более простое, но оно работает :)
Если Вы предположите, что первый день Вашего определения недели является тем же днем как 1-й день года, то это будет работать:
int year = 2000;
int week = 9;
int month = new DateTime(year, 1, 1).AddDays(7 * (week - 1)).Month;
Очевидно, истинный ответ зависел бы от того, как Вы определяете первый день недели, и как Вы определяете, как неделя попадает в месяц, когда он перекрывает больше чем один.
Другая проблема, с которой Вы могли столкнуться, состоит в том, что большинство лет не запускается в начале недели, которая смещает все.
Вы наклоняетесь. Вам требуется, по крайней мере, день, в который запускается 1-я неделя (или когда неделя запускается), для получения точного ответа.
Я думаю, что Вы предполагаете, что "неделя" является любой группой 7 последовательных дней. Это не. Учитывая год (2008), Неделя (5), Вы могли быть или в январе или в Febuary, в зависимости от того, когда Ваша "неделя" запускается.
Вы наклоняетесь. Неделя может запуститься через один месяц и конец в другом.