|
0 / 0 / 0
Регистрация: 10.05.2024
Сообщений: 6
|
||||||
Обновление данных в Dictionary10.05.2024, 12:20. Показов 1889. Ответов 23
Метки нет (Все метки)
Всем привет!
Есть dict Dim dict As Object Есть Set dict = CreateObject("Scripting.Dictionary") Я в него пытаюс положить самую раннюю дату выдачи материала, и количество выданного материала. Ключ - наименование материала. Проблема с dict(material)(0) = CLng(dict(material)(0)) + quantity - не считает сумму, при отладке проходит с датами таже беда, пишет первую дату из таблицы, дальше проходит условие If dateOut < CDate(dict(material)(1)) Then но данные в dict не изменяет
0
|
||||||
| 10.05.2024, 12:20 | |
|
Ответы с готовыми решениями:
23
Определить тип данных Dictionary BackgroundWorker запись данных в Dictionary |
|
12030 / 5822 / 1491
Регистрация: 05.10.2016
Сообщений: 16,399
|
|
| 10.05.2024, 12:29 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 10.05.2024
Сообщений: 6
|
|
| 10.05.2024, 12:45 [ТС] | |
|
Вот
0
|
|
|
3946 / 2339 / 790
Регистрация: 02.11.2012
Сообщений: 6,214
|
|
| 10.05.2024, 13:01 | |
|
в xlsx макросы не живут.
0
|
|
|
0 / 0 / 0
Регистрация: 10.05.2024
Сообщений: 6
|
|
| 10.05.2024, 13:07 [ТС] | |
|
Вот 2
0
|
|
|
12030 / 5822 / 1491
Регистрация: 05.10.2016
Сообщений: 16,399
|
|||||||
| 10.05.2024, 13:33 | |||||||
|
Держите: Бед всякой дури - типа словарей:
- Проверяйте!
0
|
|||||||
|
0 / 0 / 0
Регистрация: 10.05.2024
Сообщений: 6
|
|
| 10.05.2024, 13:51 [ТС] | |
|
Так же как и в моем случае, выдает список уникальных наименований, даты - выдает первые из сходной таблицы, количество выданного также не суммирует.
Тоесть имею исходную таблицу 21.04.2024 МФУ Canon i-Sensys MF446x 3514C006 Картридж 1,00 шт 17.04.2024 МФУ Canon i-Sensys MF446x 3514C006 Картридж 1,00 шт 12.04.2024 МФУ Canon i-Sensys MF446x 3514C006 Картридж 1,00 шт 06.04.2024 МФУ Canon i-Sensys MF446x 3514C006 Картридж3 1,00 шт 02.04.2024 МФУ Canon i-Sensys MF446x 3514C006 Картридж3 1,00 шт 10.03.2024 МФУ Canon i-Sensys MF446x 3514C006 Картридж 1,00 шт 24.02.2024 МФУ Canon i-Sensys MF446x 3514C006 Картридж 1,00 шт в итоговой хочу получить - Картридж 5 24.02.2024 Картридж3 2 02.04.2024
0
|
|
|
12030 / 5822 / 1491
Регистрация: 05.10.2016
Сообщений: 16,399
|
|||||||
| 10.05.2024, 13:56 | |||||||
|
Было в пост#1 "..., и количество выданного материала. " ![]() Ну ничего страшного - измените запрос так:
![]() ... взял содержимое третьего листа примера за "желаемый результат" ...
1
|
|||||||
|
2751 / 1725 / 779
Регистрация: 23.03.2015
Сообщений: 5,449
|
||||||
| 10.05.2024, 14:05 | ||||||
|
Igor_AIR,
С дурью -типа словарей:
1
|
||||||
|
0 / 0 / 0
Регистрация: 10.05.2024
Сообщений: 6
|
|
| 10.05.2024, 14:16 [ТС] | |
|
Работает! Спасибо! SQL запросы в екселе еще не пихал до этого ))
0
|
|
|
12030 / 5822 / 1491
Регистрация: 05.10.2016
Сообщений: 16,399
|
||||||||
| 10.05.2024, 14:33 | ||||||||
|
Настоятельно рекомендую, работает на порядок быстрее. ![]() Добавлено через 8 минут Igor_AIR, Да! -чуть не забыл ! Если у вас в исходном материале могут быть нулевые количества , то условие отбора в запросе лучше изменить на например так:
... WHERE (F3 Is Not Null) ... = "Наименование заполнено (не пустое)"
0
|
||||||||
|
2751 / 1725 / 779
Регистрация: 23.03.2015
Сообщений: 5,449
|
|
| 10.05.2024, 14:35 | |
|
0
|
|
|
12030 / 5822 / 1491
Регистрация: 05.10.2016
Сообщений: 16,399
|
|||||||
| 10.05.2024, 15:30 | |||||||
|
На малых объёмах данных (500 -1000 записей) вариант от ув. Narimanych работает в несколько раз быстрее моего. А вот уже на 5 000-ах записей результат машина выдала такой:
Получаем: Мой способ годится только для больших объёмов. Успехов!
1
|
|||||||
|
6997 / 2895 / 555
Регистрация: 19.10.2012
Сообщений: 8,803
|
||||||
| 10.05.2024, 22:47 | ||||||
|
Да и первый код можно наладить, но так в массив не запишет - нужно массив извлечь из словаря, записать в этот массив, положить массив назад в словарь.
Добавлено через 10 минут Ничего не оптимизировал, просто наладил что было показано
Вообще я бы в данном случае завёл 2 словаря - код короче, и писать меньше...
1
|
||||||
|
0 / 0 / 0
Регистрация: 10.05.2024
Сообщений: 6
|
|
| 11.05.2024, 10:01 [ТС] | |
|
Спасибо, паложить в два словаря тоже пробовал!
0
|
|
|
sleep
4914 / 4551 / 837
Регистрация: 13.04.2015
Сообщений: 9,676
|
||||||||
| 11.05.2024, 10:20 | ||||||||
|
Вместо этого:
0
|
||||||||
|
6997 / 2895 / 555
Регистрация: 19.10.2012
Сообщений: 8,803
|
||||||||||||
| 11.05.2024, 19:30 | ||||||||||||
Добавлено через 12 минут При моём подходе чтоб сохранить минимальную дату нужно сперва записать первую, затем проверять на существование ключа и сверять текущую с предыдущей... Добавлено через 4 часа 18 минут Вот так отбирает минимальную дату:
0
|
||||||||||||
|
|
|||||||
| 11.05.2024, 19:32 | |||||||
0
|
|||||||
|
6997 / 2895 / 555
Регистрация: 19.10.2012
Сообщений: 8,803
|
|
| 11.05.2024, 19:45 | |
|
Интересно померить на 10к насколько быстрее будет на двух словарях и без массива в итем.
Или медленнее ((
0
|
|
|
12030 / 5822 / 1491
Регистрация: 05.10.2016
Сообщений: 16,399
|
||
| 11.05.2024, 21:59 | ||
![]() Удалено уж давно всё ... Я просто размножил строки из примера, кол-во по возрастанию.
1
|
||
| 11.05.2024, 21:59 | |
|
Помогаю со студенческими работами здесь
20
Обновление базы и ошибка: Обновление невозможно. База данных или объект доступны только для чтения. Поиск ключей и данных в коллекции Dictionary class <T> и Dictionary со свободным типом данных Dictionary как источник данных для dataGridView Считывание базу данных из текстового файла и записывание в Dictionary<> Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|