Аватар для bodynar
345 / 307 / 135
Регистрация: 14.03.2015
Сообщений: 1,158
Записей в блоге: 1

Добавление недостающих дней в коллекцию

24.03.2016, 13:45. Показов 1001. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.

У меня имеется коллекция DateTime.
В коллекции содержатся объекты, у которых поле DayOfWeek может быть одинаково.

Также в коллекции отсутствуют некоторые элементы, у которых DayOfWeek отличается от других элементов.

Проще говоря - у меня есть коллекция дат, раскиданных по одной неделе, но некоторых дат там не имеется - некоторых конкретных дней (например нету понедельника или среды).

Есть ли вариант дополнить коллекцию недостающими элементами, дата которых будет вычислена из уже имеющихся элементов?

Т.е. если у нас есть вторник, то дата понедельника может быть вычислена через .AddDays(-1);.

Не могли бы вы подсказать универсальный алгоритм?

Спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.03.2016, 13:45
Ответы с готовыми решениями:

Добавление элементов в коллекцию
Здравствуйте. Подскажите, пожалуйста, как ввести с клавиатуры 5 элементов коллекции ArrayList? При компиляции после ввода первого значения,...

Циклическое добавление в коллекцию
Всем доброго времени. Возникла такая проблема : Нужно добавить строки из Таблицы в коллекцию FundCollection, где столбику соответствует...

Добавление элемента в коллекцию List
Здравствуйте, при работе с коллекциями строк возникла такая проблема, можно ли добавить в коллекцию новый элемент на указанную позицию (не...

6
94 / 94 / 36
Регистрация: 01.10.2014
Сообщений: 229
24.03.2016, 13:55
bodynar, Можете с примером? а то не очень понятно что в исходных данных и соответственно не ясно что на выходе должно быть
0
 Аватар для bodynar
345 / 307 / 135
Регистрация: 14.03.2015
Сообщений: 1,158
Записей в блоге: 1
24.03.2016, 13:58  [ТС]
Есть идея в таком роде: в цикле прогонять и создавать даты дней, исходя из одной имеющейся даты
C#
1
2
var days = Enum.GetNames(typeof(DayOfWeek));
var date = min.AddDays(-i);
И проверять существует ли в коллекции дата с таким днем недели, если нет - добавляем в коллекцию.

Но чет кажется, что варварский метод.

Добавлено через 3 минуты
SailarmoonKS, Ну, вопрос я сильно упростил.
Если конкретно - у меня имеется сие:
C#
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
public class iDay : ObservableCollection<Event>
    {
        public string Day
        {
            get
            {
                return Date.DayOfWeek + "\n" + _date.ToString("d");
            }
        }
 
        public DateTime Date
        {
            get
            {
                return _date;
            }
            set
            {
                if (value != null)
                    _date = value;
            }
        }
 
        private DateTime _date;
 
        public iDay(IEnumerable<Event> collection)
        {
 
            foreach (var event_ in collection)
            {
                Add(event_);
            }
 
            Date = this[0].TimeStart;
        }
 
        public iDay(DateTime Date)
        {
            this.Date = Date;
        }
 
    }

Которое используется здесь:
c#
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
public class iWeek : ObservableCollection<iDay>
    {
        public string WeekRange { get; set; }
 
        public iWeek(List<Event> list)
        {
            List<iDay> temp = new List<iDay>();
 
            foreach (var item in list.GroupBy(x => x.TimeStart.DayOfWeek))
            {
                temp.Add(new iDay(item.OrderBy(x => x.Description)));
            }
 
 
            foreach (var item in temp.OrderBy(x => x.Date))
            {
                Add(item);
            }
 
            RangeMaking(list);
 
            CreatingItems();
        }
 
        private void CreatingItems()
        {
            ???
        }
 
        private void RangeMaking(List<Event> list)
        {
            var min = list.Min(x => x.TimeStart);
            if (min.DayOfWeek != DayOfWeek.Monday)
                min = min.AddDays(-(int)min.DayOfWeek + 1);
 
            var max = list.Max(x => x.TimeStart);
 
            if (max.DayOfWeek != DayOfWeek.Saturday || max.DayOfWeek != DayOfWeek.Sunday)
                max = max.AddDays(-(int)max.DayOfWeek + 7);
 
            WeekRange = min.ToString("d") + " - " + max.ToString("d");
        }
        // ...
    }

На входе имеются данные, которые группируются по дням недели и сортируются.
Мне необходимо досоздавать пустые коллекции с недостающими днями недели.
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18308 / 14232 / 5368
Регистрация: 17.03.2014
Сообщений: 28,904
Записей в блоге: 1
24.03.2016, 14:55
bodynar, находим минимальную и максимальную дату. Генерируем даты в этом диапазоне. Проходим коллекцию объектов и удаляем из списка дат те что встретились. Даты которые остались очевидно и являбтся недостающими.
0
Эксперт .NET
 Аватар для Rius
13205 / 7733 / 1681
Регистрация: 25.05.2015
Сообщений: 23,576
Записей в блоге: 14
24.03.2016, 15:50
bodynar, Вам надо получить все даты в той неделе, в которой находится одна указанная дата?

Добавлено через 13 минут
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Globalization;
using System.Linq;
 
namespace bodynar
{
    class Program
    {
        static void Main(string[] args)
        {
            DateTime inputDate = DateTime.Now;
            DateTimeFormatInfo dfi = DateTimeFormatInfo.CurrentInfo;
            int daysFromWeekStarted = inputDate.DayOfWeek - dfi.FirstDayOfWeek;
 
            IEnumerable<DateTime> datesOfWeek = Enumerable.Range(-daysFromWeekStarted, 7)
                .Select(x => inputDate.AddDays(x));
 
            Debug.WriteLine("Now: {0}", inputDate);
 
            foreach (var item in datesOfWeek)
            {
                Debug.WriteLine("Day of week: {0} {1}", item.DayOfWeek, item);
            }
        }
    }
}
Now: 03/24/2016 17:49:27
Day of week: Monday 03/21/2016 17:49:27
Day of week: Tuesday 03/22/2016 17:49:27
Day of week: Wednesday 03/23/2016 17:49:27
Day of week: Thursday 03/24/2016 17:49:27
Day of week: Friday 03/25/2016 17:49:27
Day of week: Saturday 03/26/2016 17:49:27
Day of week: Sunday 03/27/2016 17:49:27
0
 Аватар для bodynar
345 / 307 / 135
Регистрация: 14.03.2015
Сообщений: 1,158
Записей в блоге: 1
24.03.2016, 16:01  [ТС]
OwenGlendower, такой способ пытался реализовать.

На помутненном сознании накидал такое:
Кликните здесь для просмотра всего текста
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
 List<iDay> kkk(List<iDay> inn)
        {
            var tempest = inn;
 
            var min = inn.Min(x => x.Date);
            if (min.DayOfWeek != DayOfWeek.Monday)
                min = min.AddDays(-(int)min.DayOfWeek + 1);
 
            var max = inn.Max(x => x.Date);
 
            if (max.DayOfWeek != DayOfWeek.Saturday || max.DayOfWeek != DayOfWeek.Sunday)
                max = max.AddDays(-(int)max.DayOfWeek + 7);
 
            if (!ContainsDay(inn, min.DayOfWeek))
                tempest.Add(new iDay(min));
 
            //if (!ContainsDay(inn, max.DayOfWeek))
            //    tempes.Add(new iDay(max));
 
            for (int i = 1; i < 7; i++)
            {
                var date = min.AddDays(i);
                if (date > max)
                    break;
 
                if (date.DayOfWeek == DayOfWeek.Sunday)
                    continue;
 
                if (!ContainsDay(inn, date.DayOfWeek))
                    tempest.Add(new iDay(date));
            }
            tempest = tempest.OrderBy(x => x.Date.DayOfWeek).ToList();
            return tempest;
        }
 
        bool ContainsDay(List<iDay> inn, DayOfWeek date)
        {
            var contains = false;
 
            foreach (var item in inn)
            {
                if (item.Date.DayOfWeek == date)
                    contains = true;
            }
 
            return contains;
        }
Вроде работает, но грамотно ли?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18308 / 14232 / 5368
Регистрация: 17.03.2014
Сообщений: 28,904
Записей в блоге: 1
24.03.2016, 16:57
bodynar, по моему данный алгоритм неправильно двигает даты на начало и конец недели. Плюс проверка на наличие минимальной и максимальной дат не нужна. Я бы сделал так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
List<iDay> kkk(List<iDay> inn)
{
    //if (inn.Count == 0) return inn;
    
    DateTime min=DateTime.MaxValue, max=DateTime.MinValue;
    for (int i=0; i<inn.Count; i++)
    {
        if (inn[i].Date > max) max = inn[i].Date;
        else if (inn[i].Date < min) min = inn[i].Date;
    }
    if (min.DayOfWeek != DayOfWeek.Monday)
        min = min.AddDays(- ((int)min.DayOfWeek == 0 ? 7 : (int)min.DayOfWeek)+1);
    if (max.DayOfWeek != DayOfWeek.Saturday || max.DayOfWeek != DayOfWeek.Sunday)
        max = max.AddDays((int)max.DayOfWeek == 0 ? 0 : 7-(int)max.DayOfWeek);
    
    int days = (max.Date - min.Date).Days;
    var missingDays = Enumerable.Range(1, days).Select(n => min.Date.AddDays(n)).Except(inn.Select(x => x.Date.Date));
    inn.AddRange(missingDays.Select(d => new iDay(d)));
    
    return inn;
}
P.S. Называть типы с буквы i плохая идея.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.03.2016, 16:57
Помогаю со студенческими работами здесь

Добавление/проверка массива в коллекцию
Доброго времени суток! Извиняюсь за два вопроса в одной теме, но мне кажется, что они очень похожи. 1) Почему проверка на наличие массива...

Полиморфизм - добавление объектов в коллекцию
Для решения моей задачи хорошо подходит соответствующий пример msdn - к коллекции добавляются разные экземпляры классов фигур, которые...

Добавление элементов в коллекцию List
Доброго времени суток, исходные данные: Есть строка str = &quot;a, b&quot;; Коллекция list&lt;list&lt;string&gt;&gt;ls = new...

Добавление элемента в коллекцию при считывании с StreamReader
public List&lt;string&gt; TEMP; string line; while ((line = sr.ReadLine()) != null) { TEMP.Add(line);...

Добавление строк и элементов в коллекцию для коллекций <List<List<T>
Доброго времени суток , никак не могу добавить строку в коллекцию коллекций . У меня нет определенного количества данных . Могли б...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru