С Новым годом! Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/18: Рейтинг темы: голосов - 18, средняя оценка - 4.50
37 / 5 / 3
Регистрация: 30.11.2011
Сообщений: 530
1

Как ограничить диапазон использованных ячеек?

13.08.2018, 15:23. Показов 3558. Ответов 10

Author24 — интернет-сервис помощи студентам
Здравствуйте!

Скажите, пожалуйста, как ограничить диапазон ActiveSheet.UsedRange ячейками от A1 до последней ячейки в столбце, в котором в первых 9 строках есть значение "Долгота"?

Добавлено через 50 минут
Попробовал так:
Visual Basic
1
2
3
4
5
6
7
    Dim currCell, last As Range
    Set currCell = ActiveSheet.Cells.Find(What:="Долгота", SearchFormat:=False)
    If currCell.Parent.Cells(ActiveSheet.Rows.Count, currCell.Column) <> "" Then _
            last = currCell.Parent.Cells(ActiveSheet.Rows.Count, currCell.Column)
    If currCell.Parent.Cells(ActiveSheet.Rows.Count, currCell.Column) = "" Then _
            last = currCell.Parent.Cells(ActiveSheet.Rows.Count, currCell.Column).End(xlUp)
    Set filled_range2 = Range(ActiveSheet.Cells(1, 1), last)
но что-то не сработало "Object variable or with block variable not set (Error 91)" на втором if
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.08.2018, 15:23
Ответы с готовыми решениями:

Как определить диапазон использованных ячеек?
Проблема в следующем: необходимо данные с листа, которые располагаются в один столбец, поместить в...

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

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

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

10
oh my god
1455 / 794 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
13.08.2018, 15:41 2
Есть функция защита листа, от изменений от вставок и тд
0
37 / 5 / 3
Регистрация: 30.11.2011
Сообщений: 530
13.08.2018, 15:43  [ТС] 3
Цитата Сообщение от fever brain Посмотреть сообщение
Есть функция защита листа, от изменений от вставок и тд
Спасибо. Я не так выразился, похоже. Извините.
Метод ActiveSheet.UsedRange выделяет в диапазон больше столбцов, чем нужно. Поэтому конечный диапазон должен быть ограниченным по сравнению с возвращаемым ActiveSheet.UsedRange. При этом столбец с заголовком "Долгота" может плавать от книги к книге как по X, так и по Y. Правее этого столбца бывают данные, которые не надо брать в диапазон
0
oh my god
1455 / 794 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
13.08.2018, 16:14 4
Не понятно вообще что требуется UsedRange возвращает первую и последнюю занятую ячейку
если выше слова *долгота* будет еще чтото то ф-я возвратит высшую точку, также будет с нижней точкой
возможно придется сделать по другому
0
37 / 5 / 3
Регистрация: 30.11.2011
Сообщений: 530
13.08.2018, 16:38  [ТС] 5
Надо выделить диапазон ячеек от A1 до последней ячейки в столбце, в котором присутствует заголовок Долгота. У вас есть идея, как это можно сделать?
0
oh my god
1455 / 794 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
13.08.2018, 16:56 6
Цитата Сообщение от borro Посмотреть сообщение
У вас есть идея, как это можно сделать
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Option Explicit
 
Sub Макрос1()
    Dim c1
    With ActiveSheet
        'Находим последнее слово на листе с текстом долгота
        Set c1 = .UsedRange.Find("долгота", , xlFormulas, xlWhole, , xlPrevious)
        
        'выделяем этот диапазон
        .Range([a1], c1).Select
 
    End With
 
End Sub
Миниатюры
Как ограничить диапазон использованных ячеек?  
0
37 / 5 / 3
Регистрация: 30.11.2011
Сообщений: 530
13.08.2018, 17:14  [ТС] 7
Спасибо. Только под ячейкой со значением "Долгота" тоже будут данные, которые надо включить в диапазон. При этом не факт, что последняя(максимальная по координате Y) заполненная ячейка в столбце, в котором стоит "Долгота", она может быть в любом предыдущем столбце. И максимальную координату Y надо брать по этой самой нижней ячейке. Приложил пример с искомым диапазоном
Вложения
Тип файла: xlsx Пример.xlsx (9.6 Кб, 4 просмотров)
0
oh my god
1455 / 794 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
13.08.2018, 17:34 8
ну так сделай
возьми координаты поиска из c1 и координаты последней заполненной
потом порученный cells вставь в искомый диапазон (Range)
мне самому чтоли это делать ? Может мне зарплату за тебя получить
0
37 / 5 / 3
Регистрация: 30.11.2011
Сообщений: 530
13.08.2018, 18:12  [ТС] 9
Я пока не знаю, как найти координату Y самой нижней заполненной ячейки, причем из тех, что не правее столбца со значением "Долгота" в одной из ячеек
0
oh my god
1455 / 794 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
14.08.2018, 09:34 10
Лучший ответ Сообщение было отмечено borro как решение

Решение

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Option Explicit
 
Sub Определитель_долготы()
    Dim r&, cl
    
    With ActiveSheet
    
        'Ищим паследнее слово на листе с текстом долгота
        Set cl = .UsedRange.Find("долгота", SearchDirection:=xlPrevious)
        
        'Находим последний Y в табл
         r = .UsedRange.Row + .UsedRange.Rows.Count - 1
 
        'именуем этот диапазон
        .Range([a1], .Cells(r, cl.Column)).Name = "borro"
        
        'и выделяем его чтобы borro его увидел
        .Range("borro").Select
        
    End With
 
End Sub
Миниатюры
Как ограничить диапазон использованных ячеек?  
1
37 / 5 / 3
Регистрация: 30.11.2011
Сообщений: 530
14.08.2018, 09:57  [ТС] 11
Спасибо! Добавил в закладки. Хорошего дня!
0
14.08.2018, 09:57
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.08.2018, 09:57
Помогаю со студенческими работами здесь

Как скопировать непрерывный диапазон ячеек?
Доброго времени суток! Помогите пожалуйста в решении проблемы. Необходимо скопировать диапазон...

Как передать в формулу диапазон ячеек?
Здравствуйте, у меня такая проблема.. В общем надо программно работать с матриицей,введенной с...

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

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


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Что такое HCL Notes и как с ним работать
InfoMaster 10.01.2025
HCL Notes (ранее известный как IBM Notes и Lotus Notes) представляет собой комплексную платформу для совместной работы и обмена информацией в корпоративной среде. Это многофункциональное решение,. . .
Как работать с Git из Windows и Visual Studio
InfoMaster 10.01.2025
Работа с Git в Windows Работа с Git в операционной системе Windows может быть осуществлена с помощью различных инструментов, каждый из которых обладает своими уникальными возможностями и. . .
Аналог оператора switch case в Python
InfoMaster 10.01.2025
Оператор switch case используется в программировании для выбора одного из нескольких вариантов исполнения кода. Однако в языке Python этот оператор отсутствует. Понимание аналогов switch case в. . .
Отличия абстрактного класса от интерфейса
InfoMaster 10.01.2025
В современной разработке программного обеспечения существуют два основных механизма реализации абстракции: абстрактные классы и интерфейсы. Эти инструменты, хотя и схожи в своей основной цели -. . .
Как работать в Git
InfoMaster 10.01.2025
Git — это одна из наиболее популярных систем контроля версий, которая активно используется разработчиками по всему миру. Она позволяет эффективно управлять изменениями в коде, координировать работу. . .
Реализация передвижения персонажа в Unity3d на C#
InfoMaster 10.01.2025
Реализация передвижения персонажа в Unity3D начинается с правильной настройки проекта. Этот этап критически важен для создания отзывчивого и плавного управления. Рассмотрим основные шаги для создания. . .
Docker: руководство для начинающих
InfoMaster 10.01.2025
В современном мире разработки программного обеспечения контейнеризация стала неотъемлемой частью процесса создания и развертывания приложений. Docker, как ведущая платформа контейнеризации, произвела. . .
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru