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

Поиск текста

06.12.2017, 09:51. Показов 2572. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Возникла следующая проблема:
Необходимо найти все ячейки в диапазоне А10:А50, содержащие слово qwe.
После этого в соответствующие строки столбца B вписать эти значения + значение строки ниже через знак ";".

Например:
Столбец А
qwe
rty
12
15
qwe-1
58

В столбце В должно получиться следующее:
qwe;rty
rty
12
15
qwe-1;58
58
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.12.2017, 09:51
Ответы с готовыми решениями:

Поиск по фрагменту текста
Доброго времени суток. Есть два столбца А и В с текстовыми данными. Нужно, через цикл, чтобы макрос брал текст из ячейки В1, вырезал...

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

Поиск текста в документах Word
Есть код ВБА. Он работает .. нигде не могу найти команды!!!! Может кто-то поможет ....Код для ексель ... открывает из выбранной папки файлы...

9
3947 / 2340 / 790
Регистрация: 02.11.2012
Сообщений: 6,220
06.12.2017, 10:33
Visual Basic
1
2
3
For each cl in Selection
    If cl.value = "qwe" Then cl.value = cl.value & ";" & cl.Offset(1).value
next
1
oh my god
 Аватар для fever brain
1456 / 796 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
06.12.2017, 10:36
---
0
oh my god
 Аватар для fever brain
1456 / 796 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
06.12.2017, 10:43
Лучший ответ Сообщение было отмечено Batosay как решение

Решение

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
Sub Заполнить()
    Dim a, i&, j&
    a = Split("Например:\\Столбец А\\qwe\\rty\\12\\15\\qwe-1\\58", "\\")
    On Error Resume Next
    With [a10:a50]
        For i = 1 To .Cells.Rows.Count: For j = 1 To .Cells.Columns.Count
            .Cells(i, j).Value = a(i - 1)
        Next j, i
    End With
End Sub
 
Sub Сделать()
    Dim i&, j&
    With [a10:a50]
        For i = 1 To .Cells.Rows.Count: For j = 1 To .Cells.Columns.Count
            With .Cells(i, j)
                If InStr(1, .Value, "qwe") Then
                    i = i + 1
                    Cells(.Row, .Column + 1) = .Value & ";" & Cells(.Row + 1, .Column)
                End If
            End With
        Next j, i
    End With
End Sub
Изображения
 
1
Заблокирован
06.12.2017, 10:45
Цитата Сообщение от Vlad999 Посмотреть сообщение
If cl.value = "qwe"
Visual Basic
1
If instr(cl.value, "qwe")
-если следовать задаче...
0
oh my god
 Аватар для fever brain
1456 / 796 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
06.12.2017, 10:53
Цитата Сообщение от Остап Бонд Посмотреть сообщение
If instr(cl.value, "qwe")
If instr([Start],cl.value, "qwe")
0
Заблокирован
06.12.2017, 10:58
Цитата Сообщение от fever brain Посмотреть сообщение
а для меня замечания будут ?
Естественно.
Цитата Сообщение от Batosay Посмотреть сообщение
В столбце В должно получиться следующее:
qwe;rty
rty
12
15

qwe-1;58
58
Где выделенные значения в вашем ответе?
Цитата Сообщение от fever brain Посмотреть сообщение
[Start]
- необязательный параметр, если ищем с начала строки (или что вы хотели сказать этим выделением???)
1
oh my god
 Аватар для fever brain
1456 / 796 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
06.12.2017, 11:05
Лучший ответ Сообщение было отмечено Batosay как решение

Решение

Цитата Сообщение от Остап Бонд Посмотреть сообщение
необязательный параметр
в vba необязательный, забыл про это
Исправил все
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Sub Заполнить()
    Dim a, i&, j&
    a = Split("Например:\\Столбец А\\qwe\\rty\\12\\15\\qwe-1\\58", "\\")
    On Error Resume Next
    With [a10:a50]
        For i = 1 To .Cells.Rows.Count: For j = 1 To .Cells.Columns.Count
            .Cells(i, j).Value = a(i - 1)
        Next j, i
    End With
End Sub
 
Sub Сделать()
    Dim i&, j&, ii&
    With [a10:a50]
        For i = 1 To .Cells.Rows.Count: For j = 1 To .Cells.Columns.Count
            With .Cells(i, j)
                ii = Abs(InStr(.Value, "qwe") > 0): i = i + ii
                Cells(.Row, .Column + 1) = .Value & IIf(ii, ";" & Cells(.Row + 1, .Column), "")
            End With
        Next j, i
    End With
End Sub
Изображения
 
0
Заблокирован
06.12.2017, 11:13
rty и 58 без пары остались?
Visual Basic
1
2
3
4
Dim cl As Range
For Each cl In Selection
    If InStr(cl.Value, "qwe") Then cl.Offset(, 1) = cl & ";" & cl.Offset(1) Else cl.Offset(, 1) = cl
Next
Добавлено через 1 минуту
Цитата Сообщение от fever brain Посмотреть сообщение
: i = i + ii
- это лишнее.
1
oh my god
 Аватар для fever brain
1456 / 796 / 161
Регистрация: 05.01.2016
Сообщений: 2,307
Записей в блоге: 8
06.12.2017, 11:24
Тогда в идеале должно быть так:
Visual Basic
1
2
3
4
5
6
Sub Сделать()
    Dim cl As Range
    For Each cl In [a10:a50] 'только диапазон Selection не использовать
        If InStr(cl.Value, "qwe") Then cl.Offset(, 1) = cl & ";" & cl.Offset(1) Else cl.Offset(, 1) = cl
    Next
End Sub
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.12.2017, 11:24
Помогаю со студенческими работами здесь

Поиск текста внутри файлов
Стоит задача: Поиска текста в Word-ких и не только (.txt) документах. Есть ли для этого, готовые ocx компоненты, примеры или может...

Word: поиск текста в таблице
Можно ли как-то организовать поиск текста в таблице? Или для этого достаточно обычного поиска текста?

Поиск цветной заливки текста
Добрый вечер всем! Прошу помочь! как в вордовском документе найти произвольный текст с цветной заливкой(shade), не путать с...

Поиск и замена текста в надписях
Здравствуйте, форумчане. Необходимо решить проблему в крайние сроки. Может решение у меня под носом, но голова не варит( В общем есть...

Поиск и редактирование текста в Word
Народ, помогите со следующей проблемкой. Пытаюсь написать код в VBA для обработки документа. Задача такова: нужно искать в тексте...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
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-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru