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

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

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

Author24 — интернет-сервис помощи студентам
Такой вопрос:
есть такой код:
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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
05.12.2012, 18:21
Ответы с готовыми решениями:

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

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

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

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

8
15151 / 6424 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
05.12.2012, 19:47 2
Ход мыслей правильный
Дело в том, что аргументом метода 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  [ТС] 3
Цитата Сообщение от Казанский Посмотреть сообщение
Дело в том, что аргументом метода Intersect не может быть Nothing. Попробуйте так:
Спасибо большое! Все работает! Этак я скоро и на VBA научусь программировать)))
0
2 / 2 / 0
Регистрация: 06.05.2012
Сообщений: 40
10.12.2012, 17:06  [ТС] 4
Цитата Сообщение от Казанский Посмотреть сообщение
Дело в том, что аргументом метода 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
15151 / 6424 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
10.12.2012, 17:21 5
Range("F5:F1000").Value - это массив. Массив не может быть аргументом метода Find.
Объясните словами, что Вы хотите сделать.
0
2 / 2 / 0
Регистрация: 06.05.2012
Сообщений: 40
10.12.2012, 17:25  [ТС] 6
Мне надо скрыть столбец, если некоторый диапазон Range этого столбца - пустой.
0
15151 / 6424 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
10.12.2012, 17:31 7
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  [ТС] 8
Гениально . Спасибо большое!
0
15151 / 6424 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
10.12.2012, 17:34 9
или
Visual Basic
1
If Range("F5:F1000").Text = "" Then Columns("F").ColumnWidth = 0
1
10.12.2012, 17:34
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.12.2012, 17:34
Помогаю со студенческими работами здесь

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

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

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

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

Проверить, что введенные числа входят в диапазон с 1 по 31
Всем привет! Народ подскажите, что-то мозгов не хватает.. Как написать функцию которая на вход...

Как выделить диапазон ячеек?
Объясните ламеру как можно вставить в функцию дапазон "DNosaukums" если известны первая и последняя...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru