Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
1 / 1 / 0
Регистрация: 19.07.2011
Сообщений: 285

Как нужно преобразовать макрос чтобы лишний раз не писать тысяча If Then Else для яйчеек A B G H?

25.01.2012, 15:13. Показов 1811. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уважаемые VBA-шники у меня такой вопро-о-о-о-о--о-о-о-с как нужно преобразовать макрос чтобы лишний раз не писать тысяча If Then Else для яйчеек A B G H
всё получается но когда я ввожу 0 для просмотра всех лет ничего не получается
смотрите модуль
По началу я написал следующее
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If ActiveSheet.Range("F3").Value = "01" Then
    Selection.AutoFilter Field:=1, Criteria1:="01"
ElseIf ActiveSheet.Range("F3").Value = "02" Then
    Selection.AutoFilter Field:=1, Criteria1:="02"
.....................................
..............................................
............................................
ElseIf ActiveSheet.Range("F3").Value = "100" Then
    Selection.AutoFilter Field:=1, Criteria1:="100"
End If
End Sub
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.01.2012, 15:13
Ответы с готовыми решениями:

Не могу доделать Калькулятор( как сделать так чтобы запятую можно было писать 1 раз )
Помогите доделать калькулятор. Вроде всё работает, только вот не могу сделать так чтобы запятую можно было писать 1 раз. Иначе вылетает...

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

Как преобразовать массив, так чтобы вывести только повторяющиеся элементы один раз?
Как преобразовать массив, так чтобы вывести только повторяющиеся элементы один раз? Например числа: 4 8 8 3 5 3 1 2 Вывести должен 8 3

6
1 / 1 / 1
Регистрация: 18.06.2008
Сообщений: 329
25.01.2012, 15:52
Навскидку ничего не понял, но вижу, что всю эту байду "if/end if" можно заменить одной строкой:
Visual Basic
1
Selection.AutoFilter Field:=1, Criteria1:=ActiveSheet.Range("F3").Value
0
1 / 1 / 0
Регистрация: 19.07.2011
Сообщений: 285
25.01.2012, 16:57  [ТС]
Ja sdelal tak no vtoroe uslovie ne poluchaetsja
Visual Basic
1
2
3
4
5
6
7
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean)
If ActiveSheet.Range("F3").Value Then
    Selection.AutoFilter Field:=1, Criteria1:=ActiveSheet.Range("F3").Value
ElseIf ActiveSheet.Range("F3").Value = 1 Then
    Selection.AutoFilter Field:=0
End If
End Sub
0
1 / 1 / 1
Регистрация: 18.06.2008
Сообщений: 329
25.01.2012, 18:41
Code
1
If ActiveSheet.Range("F3").Value  [bold]ЧТО?[/bold]    Then
И вообще, что нужно получить-то?
)
0
1 / 1 / 0
Регистрация: 19.07.2011
Сообщений: 285
25.01.2012, 18:56  [ТС]
,,,,,,,И вообще, что нужно получить-то?,,,,,,
Нужно отфильтровать яйчейки A B G H
Т.е. если вписать в яйейку ActiveSheet.Range("F3") число для колонки А "05" или "06" или "07"
то фильтр показывал соответсвенно все яйчейки начинаюшиеся на 05 06 07
и если вписать "1" то фильтр показывал всё
И так далее для В G H
Спасибо
P.S. я сделал при помоши ChekBox-ов, но нужен вариант попроще
0
1 / 1 / 1
Регистрация: 18.06.2008
Сообщений: 329
25.01.2012, 19:41
Ячейки с f3 по f6 надо сделать текстовыми. А то "05" будет проблематично ввести.
0
1 / 1 / 1
Регистрация: 18.06.2008
Сообщений: 329
25.01.2012, 19:42
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
Private Sub Worksheet_Change(ByVal Target As Range)
 
If Target.Address = "$F$3" Then
If Range("F3").Value = "1" Then Selection.AutoFilter Field:=1 _
Else Selection.AutoFilter Field:=1, Criteria1:=Range("F3").Value
End If
 
If Target.Address = "$F$4" Then
If Range("F4").Value = "1" Then Selection.AutoFilter Field:=2 _
Else Selection.AutoFilter Field:=2, Criteria1:=Range("F4").Value
End If
 
If Target.Address = "$F$5" Then
If Range("F5").Value = "1" Then Selection.AutoFilter Field:=7 _
Else Selection.AutoFilter Field:=7, Criteria1:=Range("F5").Value
End If
 
If Target.Address = "$F$6" Then
If Range("F6").Value = "1" Then Selection.AutoFilter Field:=8 _
Else Selection.AutoFilter Field:=8, Criteria1:=Range("F6").Value
End If
 
End Sub
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.01.2012, 19:42
Помогаю со студенческими работами здесь

Как сделать, чтобы макрос передавал значения (нужно вывести максимум через переменную)?
#include <stdio.h> #include <malloc.h> #define MAX_ELEM(count, array) int max=array; for(int j = 0; j < n; ++j){if (array > max){max =...

Как преобразовать def str1(self): чтобы можно был писать print(h), а не print(h.str1())
Здравствуйте class Highwayman: def __init__(self, name, property1, NumberOfCheated): self.name = name ...

Что нужно освоить, чтобы писать игры
Вот имею я такоую проблему...Даже не проблему а вопрос небольшой.. Думаю,знающие люди мне на него ответят! Вот и сам вопрос: Я где-то...

Что нужно, чтобы начать писать на ASP?
Помогите кто-нибудь! Что нужно, чтобы начать писать на ASP? И где это все 'безобразие взять'!!! Help. Зарание спасибо.

Эффект CSS применяется лишь один раз, а нужно, чтобы он вызывался для каждой буквы строки
Всем привет, на этом форуме мне скинули сайт с анимацией появления текста в CSS: https://daneden.github.io/animate.css/ Скачал я эту...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru