Как я могу определить номер недели определенной даты? - PullRequest
12 голосов
/ 27 октября 2011

Я пытаюсь сделать календарь, используя 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;
    }

Ответы [ 2 ]

17 голосов
/ 27 октября 2011

Вы должны использовать 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" />
11 голосов
/ 27 октября 2011

Вы можете использовать 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
    );
}
...