2

1 年間の週数をカウントする関数を作成しましたが、問題なく動作します。問題は、月曜日の曜日を取得する方法が必要なことです。スウェーデンのカレンダーです。

以下のコードは、52 週の年にはうまく機能しますが、53 週の年 (2009 など) もあります。それから、月曜日の日付として1月から日付を取得しました(正しくない)。ですから、それがすべての年で機能するように私を助けてください。

私がおそらくできることは、その年が53週かどうかを確認してからいくつかのチェックを行うことですが、特別なチェックなしでスムーズに進みたいと思います.

これが私が思いついたものです:

    public static DateTime GetDateFromWeek(int year, int week)
    {
        //First day of the year
        DateTime d = new DateTime(year, 1, 1);
        GregorianCalendar calendar = new GregorianCalendar(GregorianCalendarTypes.MiddleEastFrench);
        d = calendar.AddWeeks(d, week);
        d = d.AddDays(1 - (double)d.DayOfWeek);
        return d;
    }
4

4 に答える 4

4

あなたの基本的な問題は、DateTime d = new DateTime(year, 1, 1);その年の最初の週にあるという仮定だと思いますが、それは前年の第 52/53 週に属する可能性があります。

ここで解決策を見つけることができます。

于 2010-03-29T10:53:55.637 に答える
2

これはそれを行う必要があります:

public static DateTime GetDateFromWeek(int year, int week)
{
    GregorianCalendar calendar = new GregorianCalendar(GregorianCalendarTypes.MiddleEastFrench);
    DateTime d = new DateTime(year, 12, 31);
    int weeksInYear = calendar.GetWeekOfYear(d, CalendarWeekRule.FirstFourDayWeek, DayOfWeek.Monday);
    int weeksToSubtract = weeksInYear - week;
    d = calendar.AddWeeks(d, -weeksToSubtract);
    d = d.AddDays(1 - (int)d.DayOfWeek);
    return d;
}
于 2010-03-29T11:06:17.743 に答える
0

あなたは次の質問を見たいと思うかもしれません、私はそれがあなたが求めているものだと思います:

週の最初の月曜日の日付を取得する

于 2010-03-29T10:44:03.927 に答える
-1
if (cmb_mode_of_service.SelectedItem.ToString() == "Weekly Service")
            {
                int year = 0;
                if (cmb_term_of_service.SelectedItem.ToString() == "One Year")
                {
                    year = 1;
                }

                if (cmb_term_of_service.SelectedItem.ToString() == "Two Year")
                {
                    year = 2;
                }

                if (cmb_term_of_service.SelectedItem.ToString() == "three year")
                {
                    year = 3;
                }

                DateTime currentdate = Convert.ToDateTime(service_start_date.Text);
                DateTime Enddate = currentdate.AddYears(+year);


                char c1 = 'A';
                int c2 = 1;
                for (var dt1 = currentdate; dt1 <= Enddate; dt1 = dt1.AddDays(7))
                {
                    DataRow dr = dt.NewRow();
                    dr["SN"] = c2++;
                    dr["serviceid"] = "S4-" + c1++;
                    dr["servicedate"] = dt1.ToString();
                    dr["servicestatus"] = "Pending";
                    dr["serviceexcutive"] = "Not Alowed";
                    dt.Rows.Add(dr);

                }
                dataGridView1.DataSource = dt;

            }
于 2015-04-29T07:28:46.103 に答える