Как определить номер недели определенной даты?
Я пытаюсь создать календарь с помощью wpf. Используя itemsPanel и более, у меня есть сетка с 7 столбцами (воскресенье-суббота) и 6 строк (неделя # месяца). Если я могу найти начальную позицию первого числа каждого месяца, получив номер недели и недели (месяца), как я могу найти номер недели (0-5 каждого месяца)? Также не могу я как-то просто заполнить календарь оттуда? Я потерян, и я не знаю, что еще попробовать.
public partial class SchedulePage : Page
{
MainWindow _parentForm;
public int dayofweek;
public SchedulePage(MainWindow parentForm)
{
InitializeComponent();
_parentForm = parentForm;
// DateTime date = new DateTime(year, month, day);
_parentForm.bindings = new BindingCamper();
_parentForm.bindings.schedule.Add(new Schedule { WeekNo = (int) getWeekNumber(), WeekDay = dayofweek });
DataContext = _parentForm.bindings;
// lblTest.Content = dates(2011, 10, 27);
}
public double getWeekNumber()
{
dayofweek = getWeekDay(2011, 10, 31);
double h = dayofweek / 7;
double g = Math.Floor(h);
return g;
}
public int getWeekDay(int year, int month, int day)
{
//year = 2011;
//month = 10;
//day = 27;
int[] t = { 0, 3, 2, 5, 0, 3, 5, 1, 4, 6, 2, 4 };
// year -= month < 3;
return (year + year / 4 - year / 100 + year / 400 + t[month - 1] + day) % 7;
}
Ответы
Ответ 1
Вы должны использовать Calendar.GetDayOfWeek и Calendar.GetWeekOfYear, предпочитая писать себя.
Вы можете гарантировать, что если вы сами напишете код обработки даты/времени, он будет содержать ошибки и не будет работать в разных локалях.
public class Row
{
public string MonthWeek { get; set; }
public string Year { get; set; }
public string Month { get; set; }
public string Day { get; set; }
public string WeekOfYear { get; set; }
}
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
var l = new List<Row>();
DateTime startDate = DateTime.Now;
DateTime d = new DateTime(startDate.Year, startDate.Month, 1);
var cal = System.Globalization.DateTimeFormatInfo.CurrentInfo.Calendar;
var ms = cal.GetWeekOfYear(new DateTime(d.Year, d.Month, 1), System.Globalization.CalendarWeekRule.FirstDay, System.DayOfWeek.Sunday);
for (var i = 1; d.Month == startDate.Month; d = d.AddDays(1))
{
var si = new Row();
var month_week = (d.Day / 7) + 1;
si.MonthWeek = month_week.ToString();
si.Month = d.Year.ToString();
si.Year = d.Month.ToString();
si.Day = d.Day.ToString();
si.WeekOfYear = cal.GetWeekOfYear(d, System.Globalization.CalendarWeekRule.FirstDay, DayOfWeek.Sunday).ToString();
l.Add(si);
}
dataGrid1.ItemsSource = l;
}
}
вместе с обязательным DataGrid в XAML:
<DataGrid AutoGenerateColumns="true" Name="dataGrid1" />
Ответ 2
Вы можете использовать Calendar.GetWeekOfYear
из глобализации, чтобы сделать это.
Здесь MSDN документирует это: http://msdn.microsoft.com/en-us/library/system.globalization.calendar.getweekofyear.aspx
Вы должны передать соответствующие свойства культуры от CultureInfo.CurrentCulture
до GetWeekOfYear
, чтобы правильно соответствовать текущей культуре.
Пример:
int GetWeekOfYear(DateTime date)
{
return Calendar.GetWeekOfYear(
date,
CultureInfo.CurrentCulture.DateTimeFormat.CalendarWeekRule,
CultureInfo.CurrentCulture.DateTimeFormat.FirstDayOfWeek
);
}
Вы можете легко изменить это на метод расширения на DateTime
:
static int GetWeekOfYear(this DateTime date)
{
return Calendar.GetWeekOfYear(
date,
CultureInfo.CurrentCulture.DateTimeFormat.CalendarWeekRule,
CultureInfo.CurrentCulture.DateTimeFormat.FirstDayOfWeek
);
}