Выбрать дату в календареВыбрать дату в календаре

Страницы: 1
По какому событию запускать макрос, чтобы контролировать заданный период времени?, Очень интересная тема по хранению информации
 
Модераторы можете поменять тему на к примеру "Отработка макроса по событию"
По какому событию запускать макрос, чтобы контролировать заданный период времени?, Очень интересная тема по хранению информации
 
Всем привет! В голове возникла идея написать макрос от несинкционированного доступа.
К примеру у меня есть пароли хранящиеся в Excel.

Возможно ли при открытие файла запускать макрос, к примеру на проверку даты.
К примеру если ставлю счетчик на месяц, то в течении месяца все норм.
Но после месяца при открытии файла должны скрыться столбцы с паролями.

Краем уха слышал про наличие в VBA событий. Это с этим связано?
Сбор данных из книги в один лист, Необходимо сформировать массив данных
 
Хотел бы от Вас услышать возможные сроки реализации, по идее чем быстрее тем лучше, могу ответить здесь на перечень вопросов или электронную почту
Сбор данных из книги в один лист, Необходимо сформировать массив данных
 
Добрый день, стоит задача написать код по сбору из листов определенной книги массива информации на отдельный лист.
Опишу более подробно.
Существует 1 книга, в книге неограниченное количество листов.
Необходимо собирать информацию с блоков только при наличии хоть одного из блоков которые буду отписаны ниже, в противном случае пропускать лист.

Лист с собираемой информацией должен выглядеть следующим образом
Название листаФильтр\
признак\
показатель
Аналитика\
Наименование
показателя
ОграничениеОбязательностьЗначение по умолчаниюМодуль/
факт/
руки
№ алгоритма (номер строки)СодержаниеРодитель 1Родитель 2Родитель 3Родитель 4Родитель 5Родитель 6Код цвета ячейкиЛегенда
теперь подробнее.

Почти на всех листах существует похожая структура. Выделю 3 основных блока и опишу работы по ним:

1 блок. Блок "Фильтров"

Заполняется на основании строк 4-18
В массиве необходимо заполнить столбцы с 1 по 6
Остальные останутся пустыми


2 блок "Аналитических Признаков"

Заполняется на основании строк 22  - 34 (признаки и показатели) а содержание заполняется с 35 и ниже.
Столбец  ограничение, обязательность, значение по умолчанию, код цвета ячейки и легенда не заполняются.
Остальные заполняются  следующим образом.
Название листа = Название листа
Фильтр/признак/показатель = Признак
Аналитика/наименование показателя =  столбцы из блока аналитические признаки
Цитата
ПРИМЕР
  • Номенклатура (Группа)
  • Ед. измерения
  • Проект
  • Направления деятельности
Модуль/факт/руки = существует 3 источника информации
(необходимо сформировать все 3 поочередно с информацией что по ним хранится, но это в след столбцах)
  • План из модулей (текстовое описание алгоритмов)
  • План (текстовое описание алгоритмов)
  • Факт (текстовое описание алгоритмов)
№ Алгоритма = под каждым из модулей существует несколько строк с описание,
1 строка - значит проставляем цифру 1, и это означает что 1 алгоритм,
2 строки - значит необходимо создать 2 строки в массиве и т.д.

Содержание = содержание ячейки по ранее проставленным признакам
(по столбцу с аналитикой, и по блоку из модуля), если под блоком несколько строк,
необходимо добавить в массив все эти строки, и у каждой будет свой № алгоритма (1,2 и т.д.)

Родители (1-n) = в некоторых блоках возможно наличие объединений, по ним необходимо определить родителей (более подробно в блоке 3)
           
3 блок "Бюджетных показателей"

Столбец  ограничение, обязательность и значение по умолчанию не заполняются.
Остальные заполняются  следующим образом.

Название листа = Название листа
Фильтр/признак/показатель = Показатель
Аналитика/наименование показателя =  столбцы из блока бюджетные показатели
Цитата
ПРИМЕР
  • Неснижаемый остаток
  • кол-во
  • сумма
Модуль/факт/руки = существует 3 источника информации (аналогично блока 2)

№ Алгоритма = под каждым из модулей существует несколько строк с описание,
1 строка - значит проставляем цифру 1, и это означает что 1 алгоритм,
2 строки - значит необходимо создать 2 строки в массиве и т.д.

Содержание = содержание ячейки по ранее проставленным признакам
(по столбцу с бюджетным показателем, и по блоку из модуля), если под блоком несколько строк,
необходимо добавить в массив все эти строки, и у каждой будет свой № алгоритма (1,2 и т.д.)

Родители (1-n) =необходимо на основании объединения составить иерархию.
Цитата
Пример
  • Родитель 1 = Бюджетные показатели
  • Родитель 2 = Январь
  • Родитель 3 = Остаток на начало периода
  • Родитель 4 = Основной склад
  • Родитель 5 = Мол
  • Родитель 6-n  = (Пусто)

Код цвета ячейки = равен коду цвета ячейки которую мы использовали для заполнения содержания.
Легенда = преобразовать код в соответствии с легендой в конце примера (в приложении).


Дополнительно для 3 блока.

Столбец  ограничение, обязательность, значение по умолчанию, код цвета ячейки и легенда не заполняются.

Необходимо произвести поиск по 1 столбцу, в случае нахождения в 1 столбце значений
"Маска хозопераций -" или "Маска хозопераций +" необходимо также заполнить данную таблицу,
по тем же условиям что и весь блок 3, но уже в  описанных ниже полях указать следующее:

Модуль/факт/руки ="Маска хоз операций
№ Алгоритма должен содержать номер и знак из хозопераций (пример 1_+, 2_- и т.д.)




Готов ответить на более подробные вопросы.
Предварительная смета на данные работы 5000 руб.
Формирование иерархии по объединению ячеек, Формирование иерархии от показателя до последнего родителя
 
нашел ответ если у кого потом в дальнейшем будет вопрос
Код
Sub tt()
For i = 2 To 5
    For j = 2 To 5
        If Cells(i, j).MergeCells Then
            Debug.Print Cells(Cells(i, j).MergeArea.Row, Cells(i, j).MergeArea.Column).Value
        Else
            Debug.Print Cells(i, j).Value
        End If
    Next
Next
End Sub
Формирование иерархии по объединению ячеек, Формирование иерархии от показателя до последнего родителя
 
Так как перечень родителей жестко зафиксирован (их 10), решил создать переменные"r" от 1 до 10. Все работало (корректно проставлялись родители где объединены столбцы), до тех пор пока не начались объединение по строкам. Макрос начал формировать некорректные данные.

Может кто сталкивался стакой проблемой? Дмаю может возможно получить информацию о свойстве объединенных ячеек?

Кусок кода по определению родителей.
Код
'3.3.2.Запонение родителя
'3.32.1.Блок присвоения родителей
    If ws_BM.Cells(22, y2) <> "" Then
        r22 = ws_BM.Cells(22, y2)
    End If
    If ws_BM.Cells(23, y2) <> "" Then
        r23 = ws_BM.Cells(23, y2)
    End If
    If ws_BM.Cells(24, y2) <> "" Then
        r24 = ws_BM.Cells(24, y2)
    End If
    If ws_BM.Cells(25, y2) <> "" Then
        r25 = ws_BM.Cells(25, y2)
    End If
    If ws_BM.Cells(26, y2) <> "" Then
        r26 = ws_BM.Cells(26, y2)
    End If
    If ws_BM.Cells(27, y2) <> "" Then
        r27 = ws_BM.Cells(27, y2)
    End If
    If ws_BM.Cells(28, y2) <> "" Then
        r28 = ws_BM.Cells(28, y2)
    End If
    If ws_BM.Cells(29, y2) <> "" Then
        r29 = ws_BM.Cells(29, y2)
    End If
    If ws_BM.Cells(30, y2) <> "" Then
        r30 = ws_BM.Cells(30, y2)
    End If
    If ws_BM.Cells(31, y2) <> "" Then
        r31 = ws_BM.Cells(31, y2)
    End If
    If ws_BM.Cells(32, y2) <> "" Then
        r32 = ws_BM.Cells(32, y2)
    End If
    If ws_BM.Cells(33, y2) <> "" Then
        r33 = ws_BM.Cells(33, y2)
    End If
    If ws_BM.Cells(34, y2) <> "" Then
        r34 = ws_BM.Cells(34, y2)
    End If
'3.3.2.1.Блок заполнения родителей
    r = 1
    If r = 0 Or ws_Massiv.Cells(x, 4) = r22 Then
        r = 0
    Else
        y3 = 10 + 1                     'столбец родителя
        ws_Massiv.Cells(x, y3) = r22
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r23 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r23
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r24 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r24
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r25 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r25
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r26 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r26
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r27 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r27
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r28 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r28
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r29 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r29
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r30 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r30
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r31 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r31
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r32 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r32
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r33 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r33
    End If
    If r = 0 Or ws_Massiv.Cells(x, 4) = r34 Then
        r = 0
    Else
        y3 = y3 + 1
        ws_Massiv.Cells(x, y3) = r34
    End If
'--------- конец блока проверки родит
Таблица 1 и массив 1 это верный вариант
а вот таблица 2 и массив 2 уже получается формируется неправильно
Долгий поиск в коллекции, Макрос работает более 3 часов конца
 
Забыл дописать, коллекция кстати тоже не маленькая 600 000 строк
Долгий поиск в коллекции, Макрос работает более 3 часов конца
 
Добрый день! Вчера поднимал вопрос по поиску в коллекции.
Спасибо большое форумчанам подсказали функцию.

Протестил на маленьком объеме все норм.

Но когда начинаю заполнять книгу в ней 3 тысячи строк и 75 столбцов, комбинацию по которым надо найти,
макрос уходить в оооооочень долго его считать

Вот код функции поиска в коллекции
Код
Function CollectionContains(myCol As Collection, checkVal As Variant) As Boolean
    On Error Resume Next
    CollectionContains = False
    Dim it As Variant
    For Each it In myCol
        If it = checkVal Then
            CollectionContains = True
            Exit Function
        End If
    Next
End Function
Вот код макроса который очень долго отрабатывает
Код
n = Sheet.Cells.SpecialCells(xlLastCell).Row              максимальное значение n 3000
        For y = 52 To 126
            For x = 5 To n
                If CollectionContains(coll_TS, Sheet.Cells(3, y) & Sheet.Cells(x, 7)) Then     'Проверка ключа в коллекции
                    Sheet.Cells(x, y) = "1"
                Else
                    Sheet.Cells(x, y) = ""
                End If
            Next
Возможно ли как-то оптимизировать код?  Конечно есть возможность запустить в ночь, но хочу развиваться в VBA и думаю есть у кого-то решение
Формирование иерархии по объединению ячеек, Формирование иерархии от показателя до последнего родителя
 
Всем привет!

Может кто подскажет как сформировать иерархию по объединению ячеек.

Файл на основании которого надо собрать в приложении
в итоге должна получится таблица вот такого:
показательродитель 1 Родитель 2….Родитель n
перечень условий.
  • листов в книге боллее 50;
  • количество родителей ограничено( максимально 15);
  • в каждой таблице может быть разное количество родителей.
Ошибка при вызове метода для коллекции vba
 
Большое спасибо Hugo. Все работает
Ошибка при вызове метода для коллекции vba
 
У меня вопрос тогда.  Все что я до этого съела и почеркнул из Майкрософт было верно? Просто по метода коллекции там прочитал, там есть метод add и item
https://msdn.microsoft.com/ru-ru/library/yb7y698k(v=vs.90).aspx
Корректно ли тогда пользоваться этим источником?
Ошибка при вызове метода для коллекции vba
 
Спасибо, завтра попробую.
Ошибка при вызове метода для коллекции vba
 
Ааа понял. Я просто здесь первый раз извините за тупость. Я просто думал там приписка была а не сообщение.
Предлагаю тему. Ошибка при вызове метода для коллекции vba
[ Закрыто] Vba работа с коллекциями, Ошибка при вызове метода для коллекции
 
Я черпаю инфу здесь https://msdn.microsoft.com/ru-ru/library/yb7y698k(v=vs.90).aspx
[ Закрыто] Vba работа с коллекциями, Ошибка при вызове метода для коллекции
 
Sub Заполнить_матрицу()
Dim wb_ABF As Workbook
Dim ws_TS As Worksheet
Dim coll_TS As New Collection
Dim cl_ABF As Variant

Set wb_ABF = ThisWorkbook
Set ws_TS = wb_ABF.Worksheets("ТС_БП-БЕ")

'===_1.Создане_коллекции_==========================================­======================
n = ws_TS.Cells.SpecialCells(xlLastCell).Row            'Последняя строка
For x = 2 To n Step 1
   coll_TS.Add ws_TS.Cells(x, 5), ws_TS.Cells(x, 4)          'Создание коллекции
   
Next

'==_2.Заполнение_матрицы_в_бджетах_===============================­=======================
For Each Sheet In wb_ABF.Worksheets
   If Sheet.Visible = True And Sheet.Name <> "Содержание" And _
      Sheet.Name <> "Контроль" And Sheet.Name <> "ТС_БП-БЕ" Then
       n = Sheet.Cells.SpecialCells(xlLastCell).Row
       For y = 52 To 126
           For x = 5 To n
               cl_ABF = Sheet.Cells(3, y) & Sheet.Cells(x, 7)
'                MsgBox cl_ABF
'                MsgBox coll_TS.Item(cl_ABF)
               If coll_TS.contains(cl_ABF) Then
                           
                   Sheet.Cells(x, y) = "1"
               End If
           Next
       Next
   End If
Next
End Sub
[ Закрыто] Vba работа с коллекциями, Ошибка при вызове метода для коллекции
 
Да я вроде прочитал только что.

можете подсказать как бы вы назвали данную тему.

Да файл сейчас прикреплю, просто с телефона небыло возможности сразу это сделать.
[ Закрыто] Vba работа с коллекциями, Ошибка при вызове метода для коллекции
 
Доброго всем вечера.
Коротко опишу что хочу сделать.
Формирует коллекцию, затем на основании коллекции хочузаполнить таблицу.
Так как в коллекции меньше комбинаций чем в таблице для заполнения, использую
Метод для коллекции  contains.

Посмотрел пример использования метода на сайт Майкрософт, вроде все верно.
так как только начинаю использовать vba, возможно накосячил в синтаксисе.
Так как возникает дебага.

Вопрос. Может кто подсказать как произвести поиск по коллекции результатом которого будет
Являться ложь/истина. Возможно существует вообще другой способ, и не через коллекции.

Спасибо.
Ошибка при вызове метода для коллекции vba
 
Хорошо спасибо. Создам новую тему.
Ошибка при вызове метода для коллекции vba
 
Помогите разобраться с методом используемым для коллекции contains
Только осваиваю азы VBA, извините за кривой код.
If coll_TS.contains(cl_ABF) Then  ---- правильный синтаксис?

Полный макрос \
Код
Sub Заполнить_матрицу()
Dim wb_ABF As Workbook
Dim ws_TS As Worksheet
Dim coll_TS As New Collection
Dim cl_ABF As Variant

Set wb_ABF = ThisWorkbook
Set ws_TS = wb_ABF.Worksheets("ТС_БП-БЕ")

'===_1.Создане_коллекции_================================================================
n = ws_TS.Cells.SpecialCells(xlLastCell).Row            'Последняя строка
For x = 2 To n Step 1
    coll_TS.Add ws_TS.Cells(x, 5), ws_TS.Cells(x, 4)          'Создание коллекции
    
Next

'==_2.Заполнение_матрицы_в_бджетах_======================================================
For Each Sheet In wb_ABF.Worksheets
    If Sheet.Visible = True And Sheet.Name <> "Содержание" And _
       Sheet.Name <> "Контроль" And Sheet.Name <> "ТС_БП-БЕ" Then
        n = Sheet.Cells.SpecialCells(xlLastCell).Row
        For y = 52 To 126
            For x = 5 To n
                cl_ABF = Sheet.Cells(3, y) & Sheet.Cells(x, 7)
'                MsgBox cl_ABF
'                MsgBox coll_TS.Item(cl_ABF)
                If coll_TS.contains(cl_ABF) Then
                           
                    Sheet.Cells(x, y) = "1"
                End If
            Next
        Next
    End If
Next
End Sub





[img][/img]
Страницы: 1
Наверх