Получить даты недели с понедельника по пятницу с заданной даты

Я хочу получить даты недели с понедельника по пятницу с заданной даты.

Предположим, что заданная дата 6-2-2013

Я хочу результат:

Monday    4-2-2013
Tuesday   5-2-2013
Wednesday 6-2-2013
Thursday  7-2-2013
Friday    8-2-2013

или Даже у меня есть неделя № 6 ... Как я могу добиться результата «О программе»

Я получаю номер недели из приведенного ниже кода

Calendar c = Calendar.getInstance();
c.set(Calendar.DAY_OF_MONTH, 6);
c.set(Calendar.MONTH, 1);
c.set(Calendar.YEAR, 2013);

int weekNo = c.get(Calendar.WEEK_OF_YEAR);

person sdg    schedule 11.02.2013    source источник
comment
Проверьте stackoverflow.com/q/8652514/1777090 . Это может помочь   -  person MysticMagicϡ    schedule 11.02.2013


Ответы (3)


От 02.06.2013:

        GregorianCalendar c = new GregorianCalendar(2013, 1, 6);
        c.add(Calendar.DAY_OF_YEAR, Calendar.MONDAY - c.get(Calendar.DAY_OF_WEEK));
        DateFormat df = new SimpleDateFormat("d-M-yyyy");
        while(c.get(Calendar.DAY_OF_WEEK) != Calendar.SATURDAY) {
            if (c.get(Calendar.YEAR) == 2013) {
                System.out.printf("%-10tA%10s%n", c.getTime(), df.format(c.getTime()));
            }
            c.add(Calendar.DAY_OF_YEAR, 1);
        }
prints

    Monday      4-2-2013
    Tuesday     5-2-2013
    Wednesday   6-2-2013
    Thursday    7-2-2013
    Friday      8-2-2013
from week 6 of 2013:

    GregorianCalendar c = new GregorianCalendar(2013, 0, 1);
    c.add(Calendar.WEEK_OF_YEAR, 6 - 1);
    c.add(Calendar.DAY_OF_YEAR, Calendar.MONDAY - c.get(Calendar.DAY_OF_WEEK));
        DateFormat df = new SimpleDateFormat("d-M-yyyy");
        while(c.get(Calendar.DAY_OF_WEEK) != Calendar.SATURDAY) {
            if (c.get(Calendar.YEAR) == 2013) {
                System.out.printf("%-10tA%10s%n", c.getTime(), df.format(c.getTime()));
            }
            c.add(Calendar.DAY_OF_YEAR, 1);
        }

отпечатки

Monday      4-2-2013
Tuesday     5-2-2013
Wednesday   6-2-2013
Thursday    7-2-2013
Friday      8-2-2013
person Evgeniy Dorofeev    schedule 11.02.2013

Попробуйте это ... Я отредактировал и добавил больше изменений в код Achintya Jha ... Работает нормально благодаря Achintya Jha

Calendar c = Calendar.getInstance();
c.set(Calendar.DAY_OF_MONTH, 14);
c.set(Calendar.MONTH, 1);
c.set(Calendar.YEAR, 2013);

int weekNo = c.get(Calendar.WEEK_OF_YEAR);

//Set the Week No
c.set(Calendar.WEEK_OF_YEAR, weekNo);

c.clear();

//Set the Week Year and the Week No
c.set(Calendar.WEEK_OF_YEAR, weekNo);
c.set(Calendar.YEAR, 2013);


SimpleDateFormat formatter = new SimpleDateFormat("EEE dd/MM/yyyy"); // PST`
//Get Week Start Date 
Date startDate = c.getTime();
//Now it will be sunday so add plus one so now it becomes Monday
c.add(Calendar.DATE, 1);
for (int i = 0; i < 5; i++) {
    //From Monday to Friday Dates will be Printed
    System.out.println(formatter.format(c.getTime()));
    c.add(Calendar.DATE, 1);
}
person Iam4fun    schedule 11.02.2013

public static void main(String[] args) {
    getWeekOfDates(2013, 2, 11);

}

private static void getWeekOfDates(int year, int month, int day) {

    Calendar c = Calendar.getInstance();
    c.set(Calendar.YEAR, year);
    c.set(Calendar.MONTH, month);
    int weekOfMonth = c.get(Calendar.WEEK_OF_MONTH);
    c.set(Calendar.WEEK_OF_MONTH, weekOfMonth);

    DateFormat df = new SimpleDateFormat("EEE dd-MM-yyyy");
    for (int i = 0; i < 5; i++) {
        System.out.println(df.format(c.getTime()));
        c.add(Calendar.DATE, 1);
    }

}

Попробуйте это: я отредактировал по вашему требованию.

Выход:

Mon 11-03-2013
Tue 12-03-2013
Wed 13-03-2013
Thu 14-03-2013
Fri 15-03-2013
person Achintya Jha    schedule 11.02.2013
comment
Я попробую это сейчас ... спасибо - person sdg; 11.02.2013
comment
Предположим, что моя данная дата 14/2... она даже добавляет даты следующей недели (т.е..) на следующей неделе в понедельник и во вторник тоже... я думаю, что должен немного изменить ваш код... Спасибо - person sdg; 11.02.2013
comment
@sdg Я отредактировал свой код по вашему требованию. - person Achintya Jha; 11.02.2013
comment
Да, спасибо..Но если я укажу дату как 14/2..?????? результат отличается - person sdg; 11.02.2013
comment
@sdg 14 — четверг, поэтому вы хотите печатать только в четверг и пятницу? - person Achintya Jha; 11.02.2013
comment
По выбору пользователя они могут выбрать любую дату в неделю... Предположим, они выбирают четверг на этой неделе с понедельника по пятницу для печати... например, 11/2,12/2,13/2,14/2,15/2 - person sdg; 11.02.2013
comment
@sdg ты нашел рабочее решение? Не могли бы вы поделиться им, чтобы он помог другим, у которых есть аналогичная проблема? Спасибо. - person Rigorous implementation; 13.11.2013