С Новым годом! Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/89: Рейтинг темы: голосов - 89, средняя оценка - 4.97
2 / 2 / 0
Регистрация: 06.05.2012
Сообщений: 40

Как проверить, что выбранный диапазон ячеек пуст

05.12.2012, 18:21. Показов 16974. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Такой вопрос:
есть такой код:
Visual Basic
1
2
3
4
Dim r As Range
With Sheets("data1").Columns(Target.Column - 1).Find(Target.Value, LookAt:=xlWhole)
Set r = Intersect(Sheets("data1").UsedRange, Sheets("data1").Range(.Item(1), .Item(1).End(xlDown))).Offset(, 1)
End With
На определенном этапе возникает ошибка object variable or with block variable not set на этой строке.
Visual Basic
1
Set r = Intersect(Sheets("data1").UsedRange, Sheets("data1").Range(.Item(1), .Item(1).End(xlDown))).Offset(, 1)
Понятия не имею что она означает.

Строка написана правильно. Ошибка возникает потому, что Intersect().Offset(,) равно нулю, пустоте и т.д.
Вопрос: Что это за строка и ошибка? Они у меня часто появляются... И можно ли написать условие, типа:
Visual Basic
1
2
3
4
5
Dim r As Range
With Sheets("data1").Columns(Target.Column - 1).Find(Target.Value, LookAt:=xlWhole)
 if Intersect(Sheets("data1").UsedRange, Sheets("data1").Range(.Item(1), .Item(1).End(xlDown))) Is Nothing Then Exit Sub
 Set r = Intersect(Sheets("data1").UsedRange, Sheets("data1").Range(.Item(1), .Item(1).End(xlDown))).Offset(, 1)
End With
Спасибо, заранее.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.12.2012, 18:21
Ответы с готовыми решениями:

SQL через ODBC: проверить перед вытаскиванием sqlread[0] что столбец не пуст
Имеется БД Access, беру оттуда строки. OdbcConnection connect = new OdbcConnection("Driver={Microsoft Access Driver...

Как деактивировать ячейку, не потеряв при этом выбранный диапазон
Здравствуйте! Нужна помощь. Но основе выбранного (вручную) диапазона нужно построить график с помощью средств VBA. Если диапазон...

Как проверить пуст ли массив?
это продолжение темы. интересует грамотность записи If Массив(0) = "" Then ' вот эта проверка мне кажется неграмотная Добавлено...

8
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
05.12.2012, 19:47
Ход мыслей правильный
Дело в том, что аргументом метода Intersect не может быть Nothing. Попробуйте так:
Visual Basic
1
2
3
4
Dim r As Range
Set r = Sheets("data1").Columns(Target.Column - 1).Find(Target.Value, LookAt:=xlWhole)
If r Is Nothing Then Exit Sub
Set r = Intersect(Sheets("data1").UsedRange, Sheets("data1").Range(r, r.End(xlDown))).Offset(, 1)
0
2 / 2 / 0
Регистрация: 06.05.2012
Сообщений: 40
05.12.2012, 20:57  [ТС]
Цитата Сообщение от Казанский Посмотреть сообщение
Дело в том, что аргументом метода Intersect не может быть Nothing. Попробуйте так:
Спасибо большое! Все работает! Этак я скоро и на VBA научусь программировать)))
0
2 / 2 / 0
Регистрация: 06.05.2012
Сообщений: 40
10.12.2012, 17:06  [ТС]
Цитата Сообщение от Казанский Посмотреть сообщение
Дело в том, что аргументом метода Intersect не может быть Nothing.
Опять не получается..((
Код:
Visual Basic
1
2
3
 Dim Rng As Range
Set Rng = Columns("F:F").Find(Range("F5:F1000").Value, LookAt:=xlWhole)
If Rng Is Nothing Then Columns("F:F").ColumnWidth = 0
Что не так? Предложение If...Is Nothing Then, при любых значениях в диапазоне "F5:F1000" (как текстовых, так и числовых), всегда ложно. Т.е. после Then ничего не выполняется.

Добавлено через 10 минут
Эта конструкция тоже не помогает:
Visual Basic
1
If Range("F5:F1000") Is Nothing Then Columns("F:F").ColumnWidth = 0
0
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
10.12.2012, 17:21
Range("F5:F1000").Value - это массив. Массив не может быть аргументом метода Find.
Объясните словами, что Вы хотите сделать.
0
2 / 2 / 0
Регистрация: 06.05.2012
Сообщений: 40
10.12.2012, 17:25  [ТС]
Мне надо скрыть столбец, если некоторый диапазон Range этого столбца - пустой.
0
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
10.12.2012, 17:31
Visual Basic
1
If Range("F5:F1000").Find("*") Is Nothing Then Columns("F").ColumnWidth = 0
2
2 / 2 / 0
Регистрация: 06.05.2012
Сообщений: 40
10.12.2012, 17:33  [ТС]
Гениально . Спасибо большое!
0
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
10.12.2012, 17:34
или
Visual Basic
1
If Range("F5:F1000").Text = "" Then Columns("F").ColumnWidth = 0
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.12.2012, 17:34
Помогаю со студенческими работами здесь

Как попросить макрос обрабатывать только выбранный диапазон, а не весь документ
Здравствуйте! Помогите, пожалуйста, переделать макрос, чтобы он работал только с выбранным участком вордовского текста, а не со всем...

Как грамотно проверить: пуст ли массив?
Создал массив, инициализировал его. Нужно его заполнить сведениями из другого массива, который обновляется постоянно (в ряде итераций). То...

Как проверить в с++ пуст файл или нет?
Добрый день! Мне нужно написать программу, которая после открытия файла делает проверку, пуст этот файл или нет. Подскажите, пожалуйста,...

Как проверить пуст или нет буфер обмена?
Есть острая необходимость проверить пуст или нет БО. Как это можно сделать средствами vb.net? Раньше было просто: Public Declare...

Обработать выделенный диапазон ячеек, результат записать в смежный диапазон
Напишите в среде Excel макрос, который в выделенном диапазоне ячеек должен выполнять заданные действия и записывать результат в смежную с...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru