Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
 Аватар для sku144
195 / 17 / 2
Регистрация: 15.01.2015
Сообщений: 190

Автоширина колонки по видимым ячейкам

14.04.2017, 00:36. Показов 2743. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть ли у кого идеи как сделать ширину колонки по самой длинной строке из диапазона видимых ячеек (в примере из диапазона А1:А9)

Visual Basic
1
2
3
4
5
6
7
8
9
Sub fff()
    Cells(1, 1) = "a"
    Cells(1, 1) = "aaa"
    ...
    Cells(9, 1) = "aa"
    Cells(10, 1) = "aaaaaaaaaaaa"
    Rows(10).Hidden = True
    Columns(1).EntireColumn.AutoFit
End Sub
Потыкался с помощью SpecialCells(xlCellTypeVisible) - не получилось.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.04.2017, 00:36
Ответы с готовыми решениями:

Не получается сделать фильтрацию по видимым ячейкам
Столкнулся с задачей фильтрации по нескольким критериям. Поскольку фильтр поддерживает только два критерия, а массив критериев не работает...

Макрос - перемещение курсора по видимым ячейкам
Здравствуйте! Пытался найти ответ на форуме и в иных местах, но с задачей не справился. Если есть подобная тема, с нужным ответом, прошу не...

Автоширина ListBox
Как заставить ListBox автоматически расширяться под размер максимального элемента (по ширине)? Если автоматически нельзя, то как в ручную?

3
3218 / 967 / 223
Регистрация: 29.05.2010
Сообщений: 2,087
14.04.2017, 06:37
Вот вариант, как идея:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
Sub fff()
    Cells(1, 1) = "a"
    Cells(2, 1) = "aaa"
    '...
    Cells(9, 1) = "aa"
    Cells(10, 1) = "aaaaaaaaaaaa"
    Rows(10).Hidden = True
    For Each x In Range("a1:a10").SpecialCells(xlCellTypeVisible)
        wd = IIf(Len(x) > wd, Len(x), wd)
    Next
    Columns.EntireColumn.ColumnWidth = wd
End Sub
1
 Аватар для mc-black
2786 / 718 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
14.04.2017, 10:01
Лучший ответ Сообщение было отмечено sku144 как решение

Решение

Зависит от шрифтов в ячейках (могут быть разными). Если доступно WinAPI, есть функция вывода длины текста в пикселях от шрифта и размещенного текста (с учетом того, что не все шрифты моноширинные). Если есть возможность применять Win API, можно копнуть документацию.

Добавлено через 47 минут
Функция GetTextExtentPoint32
1
 Аватар для mc-black
2786 / 718 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
17.04.2017, 16:00
Получилось? Хотел добавить, что когда нет возможности писать на win api, помогает применение Label с Autosize без WordWrap - передаем ему шрифт, текст - читаем Width
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.04.2017, 16:00
Помогаю со студенческими работами здесь

Автоширина блока по содержимому
Можно как то блок чтобы ширина растягивалась? <html> <head> <title>title</title> </head> <style type="text/css"> ...

Центрирование родительского блока и автоширина
Здравствуйте. Можно ли реализовать следующую задачу и, если можно, то как? Приложу код и скриншот для наглядности: <div...

Загадочно не работает автоширина столбца DataGridView :(
Приветствую! Пишу небольшую программу, которая использует в работе базу данных и DGV, в котором все отображается. Использую WinForms. Пишу...

Составить запрос, чтобы user_id из колонки comments сравнивался с id из колонки user_personal
У меня таблица comments с колонками user_id, name и page_id и есть таблица user_personal с колонками id и name Мне надо составить...

Минимальный элемент каждой колонки вычесть из данной колонки(со строками работает)
#include <iostream> #include <algorithm> #include <cmath> using namespace std; int main() { setlocale(LC_ALL,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru