Профессиональные приемы работы в Microsoft Excel

Пожалуйста, войдите или зарегистрируйтесь.


Расширенный поиск  

Новости:

Подпишитесь на рассылку новых сообщений форума через службу рассылок: Subscribe.ru

Автор Тема: Поиск значений в столбце с указанием номеров строк, в которых они находятся  (Прочитано 86 раз)

0 Пользователей и 1 Гость просматривают эту тему.

lovko

  • Постоялец
  • ***
  • Уважение: +0/-0
  • Оффлайн Оффлайн
  • Сообщений: 127

Здравствуйте! Прошу помочь с доработкой кода. Данный код ищет заданные слова в столбце, выделяет совпадения жирным и окрашивает красным. Вместо выделения совпадений, мне необходимо указывать номера строк, в которых они находятся. Перечень номеров строк необходимо вывести в Workbooks("7.0.xlsb").Sheets("Спер") в столбец А. Большое спасибо!

[/Sub Find_n_Highlight()
    On Error Resume Next: Err.Clear
    Dim ra As Range, cell As Range, res, txt$, v, pos&
    res = Workbooks("7.0.xlsb").Sheets("Сдан").Range("C2")
    If VarType(res) = vbBoolean Then Exit Sub    ' нажата кнопка ОТМЕНА
    txt$ = Trim(res): If Len(txt) = 0 Then Exit Sub    ' текст не введен, или состоит из пробелов

    Set ra = Workbooks("Сеть7.xlsb").Sheets("Срас").Range([P2], Range("P" & Rows.Count).End(xlUp))    ' диапазон для поиска
    Application.ScreenUpdating = False
    ra.Font.Color = 0: ra.Font.Bold = 0  ' сброс цветового выделения

    For Each cell In ra.Cells    ' перебираем все ячейки
        pos = 1
        If cell.Text Like "*" & txt & "*" Then
            arr = Split(cell.Text, txt, , vbTextCompare)   ' разбивает текст ячейки на части
            If UBound(arr) > 0 Then    ' если подстрока найдена
                For Each v In arr    ' перебираем все вхождения
                    pos = pos + Len(v)    ' начальная позиция
                    With cell.Characters(pos, Len(txt))
                        .Font.ColorIndex = 3    ' выделяем цветом
                        .Font.Bold = True    ' и полужирным начертанием
                    End With
                    pos = pos + Len(txt)
                Next v
            End If
        End If
    Next cell
End Subcode]
Записан

boa

  • Глобальный модератор
  • Постоялец
  • *****
  • Уважение: +26/-0
  • Оффлайн Оффлайн
  • Сообщений: 466
  • Доброта спасет мир...

Здравствуйте,
Sub Find_n_Highlight()

End Sub
    On Error Resume Next: Err.Clear
    Dim ra As Range, cell As Range, res, txt$, v, pos&
    res = Workbooks("7.0.xlsb").Sheets("Сдан").Range("C2")
    If VarType(res) = vbBoolean Then Exit Sub    ' нажата кнопка ОТМЕНА
    txt$ = Trim(res): If Len(txt) = 0 Then Exit Sub    ' текст не введен, или состоит из пробелов

    Set ra = Workbooks("Сеть7.xlsb").Sheets("Срас").Range([P2], Range("P" & Rows.Count).End(xlUp))    ' диапазон для поиска
    Application.ScreenUpdating = False
    ra.Font.Color = 0: ra.Font.Bold = 0  ' сброс цветового выделения

Dim i&: i = 1
   
    For Each cell In ra.Cells    ' перебираем все ячейки
        pos = 1
        If cell.Text Like "*" & txt & "*" Then
           
            Workbooks("7.0.xlsb").Sheets("Спер").Cells(i, 1).Value = cell.Row
            i = i + 1

'            arr = Split(cell.Text, txt, , vbTextCompare)   ' разбивает текст ячейки на части
'            If UBound(arr) > 0 Then    ' если подстрока найдена
'                For Each v In arr    ' перебираем все вхождения
'                    pos = pos + Len(v)    ' начальная позиция
'                    With cell.Characters(pos, Len(txt))
'                        .Font.ColorIndex = 3    ' выделяем цветом
'                        .Font.Bold = True    ' и полужирным начертанием
'                    End With
'                    pos = pos + Len(txt)
'                Next v
'            End If
        End If
    Next cell
End
Записан
Ничто не обходится нам так дешево и не ценится так дорого, как вежливость...  Мигель Сервантес де Сааведра
 



Темы без ответов

22.05.2018 11:38 Скрипт написать который допишет данные в файл 47
03.03.2018 00:00 Подсчет отработанного времени, за исключением заранее определенных перерывов 503
14.02.2018 10:11 Подготовить читабельную отчетность по платежам 499
23.01.2018 13:46 Найти вероятность повторной покупки 515
12.01.2018 23:56 Сделать отчет на Power BI (Dashboard) 685
06.09.2017 10:43 Solver VBA не решает гиперболическое уравнение, но при этом решает гармоническое 806
17.08.2017 12:15 Гиперссылка и фильтр одновременно макрос 1007
23.05.2017 11:20 Копирование данных из одной таблицы в умную таблицу по условию 2415
15.03.2017 15:45 автозамена картинок PowerPoint 1509
11.03.2017 13:43 Изменить нумерацию страниц 1737





Яндекс цитирования msexcel.ru Яндекс.Метрика

Страница сгенерирована за 0.115 секунд. Запросов: 107.