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

Выборка строки из диапазона ячеек и запись в textBox

18.10.2018, 16:00. Показов 2468. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть код, как исправить его так, чтобы не было выхода за границу? В текстбокс нужно ввести строку из диапазона ячеек, каждое значение ячейки разделять "|", значение строки берется из счетчика, а последняя ячейка заканчивается после 20 пустых ячеек в диапазоне
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
Row = TextBox1.Value 
Right = 2 
Emp = 0 
Do 
Emp = IIf(Cells(Row, Right).Value Is Nothing, Emp + 1, 0) 
Loop While Emp < 20 
Right = Right - 20 
res = "" 
For Each Cells In Range(Cells(Row, 1), Cells(Row, Right)) 
If Cells.Value = "" Then res = res & IIf(Len(res), "", "|") & Cells.Value 
End If 
Next Cells 
TextBox2.Value = res
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.10.2018, 16:00
Ответы с готовыми решениями:

Сцепка ячеек построчно, выборка непустых значений из диапазона и подстановка их в одну ячейку
Есть диапазон где в строках по условиям появляются значения, например: а1: стул а2: стол а3: /* пустая ячейка, т.к. условие ее...

Запись диапазона ячеек
Здравствуйте! На одном из этапов выполнения макроса мне нужно создать именованный диапазон, рекодер выдал такой код: ...

Запись в textbox диапазона строк
как в textbox из файла записать записать определенные строки ну например со 2 до 5 streamreader здесь не подходит очень нужна помощь

13
3947 / 2340 / 790
Регистрация: 02.11.2012
Сообщений: 6,220
18.10.2018, 16:34
Right = Right - 20
Right = 2 - 20 =-18 ???
0
 Аватар для theseventhline
2 / 2 / 2
Регистрация: 16.03.2015
Сообщений: 48
18.10.2018, 16:35  [ТС]
последняя ячейка заканчивается после 20 пустых ячеек в диапазоне
0
3947 / 2340 / 790
Регистрация: 02.11.2012
Сообщений: 6,220
18.10.2018, 16:43
я к тому что у вас запись не правильная, получается -18 столбец, чего не может быть.
файл покажите.
0
 Аватар для theseventhline
2 / 2 / 2
Регистрация: 16.03.2015
Сообщений: 48
18.10.2018, 16:50  [ТС]
тут нет файла с поддержкой макросов, кинула в архив
Вложения
Тип файла: rar 1.rar (76.1 Кб, 6 просмотров)
0
3947 / 2340 / 790
Регистрация: 02.11.2012
Сообщений: 6,220
18.10.2018, 17:15
какой диапазон ячеек должен попасть в текстбокс опишите словами.
не понятно что вы хотели сделать этим циклом
Visual Basic
1
2
3
Do 
Emp = IIf(Cells(Row, Right).Value Is Nothing, Emp + 1, 0) 
Loop While Emp < 20
здесь вы в цикле проверяете одну и туже ячейку, подозреваю что Row или Right должно меняться внутри цикла.
0
 Аватар для theseventhline
2 / 2 / 2
Регистрация: 16.03.2015
Сообщений: 48
18.10.2018, 18:04  [ТС]
3 строка от A3 до какой-то ячейки *3, после которой будет 20 пустых ячеек на этой строке

Добавлено через 46 минут
Vlad999,
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Private Sub TextBox2_Enter()
    Rw = TextBox1.Value
    R = 2
    Emp = 0
    Do
    R = R + 1
    Emp = IIf(Cells(Row, R).Value Is Nothing, Emp + 1, 0)
    Loop While Emp < 20
    R = R - 20
    res = ""
    For Each cell In Range(Cells(Rw, 1), Cells(Rw, R))
    If cell.Value Is Nothing Then res = res & IIf(Len(res), "", "|") & cell.Value
Next cell
TextBox2.Value = res
End Sub
выходит ошибка 1004
0
3947 / 2340 / 790
Регистрация: 02.11.2012
Сообщений: 6,220
18.10.2018, 18:18
Row нет такой переменной. Внимательнее.
0
 Аватар для theseventhline
2 / 2 / 2
Регистрация: 16.03.2015
Сообщений: 48
18.10.2018, 18:20  [ТС]
Vlad999,
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Private Sub TextBox2_Enter()
    Rw = TextBox1.Value
    R = 2
    Emp = 0
    Do
    Emp = IIf(Cells(Rw, R).Value = "", Emp + 1, 0)
    R = R + 1
    Loop While Emp < 20
    R = R - 20
    res = ""
    For Each cell In Range(Cells(Rw, 1), Cells(Rw, R))
    If cell.Value = "" Then res = res & IIf(Len(res), "", "|") & cell.Value
Next cell
TextBox2.Value = res
End Sub
теперь только прямой слэш выводит
0
3947 / 2340 / 790
Регистрация: 02.11.2012
Сообщений: 6,220
18.10.2018, 18:23
п.с. текстбокс выдаст текст по этому Cells(Rw, R) не сработает.
Rw = Cdbl(TextBox1.Value)
0
 Аватар для theseventhline
2 / 2 / 2
Регистрация: 16.03.2015
Сообщений: 48
18.10.2018, 18:27  [ТС]
Vlad999, особо не помогло(
0
3947 / 2340 / 790
Регистрация: 02.11.2012
Сообщений: 6,220
18.10.2018, 18:38
Лучший ответ Сообщение было отмечено theseventhline как решение

Решение

проходитесь пошагово (F8) по коду
Цитата Сообщение от theseventhline Посмотреть сообщение
If cell.Value = "" Then res = res & IIf(Len(res), "", "|") & cell.Value
если ячейка пустая то к значению переменной дописываем прямую черту и пусто. Вам так что ли нужно, сомневаюсь.
может так cell.Value <> "" ???
0
 Аватар для theseventhline
2 / 2 / 2
Регистрация: 16.03.2015
Сообщений: 48
18.10.2018, 19:08  [ТС]
Vlad999, вот я лопушок, а как разделить каждую ячейку символом, почему-то друг за другом слова идут?

Добавлено через 19 минут
Vlad999, спасибо большое
0
0 / 0 / 0
Регистрация: 22.02.2019
Сообщений: 21
13.09.2019, 13:44
Отлично помогли) Спасибо)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.09.2019, 13:44
Помогаю со студенческими работами здесь

Сумма диапазона ячеек в столбце и запись итога в последнюю свободную строку
Здравствуйте, скажите как посчитать сумму в столбце (Лист 3, столбец F), если в нем уже есть данные, нужно найти первую свободную ячейку в...

На панели инструментов в TextBox "Сумма" вывести сумму значений диапазона ячеек
Можно ли при переходе на определенный лист в макросе Worksheet_Activate выполнить 2 следующих события: 1. На панели инструментов в...

Как вывести значения ячеек строки DGV в каждый из TextBox
Доброе утро! Вопрос банальный и заезженный как ока моего дедушки... но все же, помогите пожалуйста! Есть DataGridView и TextBox.ов 6...

Строка. Выборка из строки нужных элементов и запись в отдельные лейблы
Имеется строка вида: Точка10; Минимальный путь от Точка0 : Точка10, Точка9, Точка6, Точка3. Мне надо взять все что после двоеточия и...

Запись строки в Textbox с правой стороны
&quot;Требуется разработать прогу, которая обрабатывает считываемый текст и выводит его же, но четные строки записываются в обратном порядке,...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru