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

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

05.12.2012, 18:21. Показов 17123. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru