Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/18: Рейтинг темы: голосов - 18, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 19.12.2014
Сообщений: 17
Excel

Поиск файла по содержимому ячейки

31.05.2018, 17:59. Показов 3784. Ответов 2
Метки vba (Все метки)

Студворк — интернет-сервис помощи студентам
Привет!
Имеется файл excel с заполненным столбцом B, нужно перебрать значения в этом столбце и как только макрос находит первую заполненную ячейку, начинает искать в той же папке где находится excel, .docx файл с таким же названием, что и текст в ячейке. Если находит такой файл, то создает в данном excel файле новый лист с тем же названием, если не находит, то ищет дальше до последней заполненной ячейки.
Подскажите пожалуйста, как это сделать.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.05.2018, 17:59
Ответы с готовыми решениями:

Поиск по содержимому ячейки
Доброго времени суток, Форумчане! Есть макрос который формирует из такой таблицы ... 01.09.2019 6:00:00 12+ ...

Поиск по содержимому ячейки
Помогите, что я делаю не так!? В ячейке А1 лист(поиск)- будет вводиться фамилия и нужно найти в листе (сбор данных), данную фамилию и...

Поиск индекса ячейки массива по её содержимому
Поверхность разбита на квадраты (пусть по 1 мм). Есть массив, описывающий координаты и цвет каждого квадрата. По поверхности требуется...

2
 Аватар для Narimanych
2751 / 1725 / 779
Регистрация: 23.03.2015
Сообщений: 5,449
01.06.2018, 08:42
Лучший ответ Сообщение было отмечено AlexFlash27 как решение

Решение

AlexFlash27, Привет.


Столбец "B" для нижеприведенного должен быть заполнен с1-ой строки..
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
25
26
27
28
29
30
Sub FOR_ALEX()
m = 0
PTH = ThisWorkbook.Path
FN = Dir(PTH & "\*.docx", vbNormal)
ReDim SHName(ThisWorkbook.Sheets.Count)
For i = 1 To ThisWorkbook.Sheets.Count
SHName(i - 1) = Sheets(i).Name
Next
 
ReDim S(m)
      Do
           If FN = "" Then Exit Do
           S(m) = Mid(FN, 1, Len(FN) - 5)
           m = m + 1
           ReDim Preserve S(m)
           FN = Dir()
     Loop
    
 
For i = LBound(S) To UBound(S) - 1
  For j = LBound(SHName) To UBound(SHName)
     If S(i) = SHName(j) Then S(i) = ""
Next
Next
 
For i = i = LBound(S) To UBound(S) - 1
If S(i) <> "" Then Worksheets.Add.Name = S(i)
Next
 
End Sub
1
0 / 0 / 0
Регистрация: 19.12.2014
Сообщений: 17
01.06.2018, 09:44  [ТС]
Спасибо работает, а еще вопрос:
У меня есть код, который ищет слово в word файле по его "окружению", и копирует его в определенную ячейку файла excel:
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
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
Sub primer()
Dim Word As Object
Dim WordDoc As Object
Dim r, f As Boolean, fO As Long
Set Word = CreateObject("Word.Application")
Set WordDoc = Word.Documents.Open(Filename:=Application.ThisWorkbook.path & "\Пример.docx")
 
Set r = WordDoc.Range
Do
With r.Find
    .ClearFormatting
    .Text = "дисциплина *относится"
    .Forward = True
    .Wrap = wdFindContinue
    .Format = False
    .MatchCase = False
    .MatchWholeWord = False
    .MatchAllWordForms = False
    .MatchSoundsLike = False
    .MatchWildcards = True
    If .Execute Then
                If f Then
                    If r.Start = fO Then
                Exit Do
                    End If
                Else
                    fO = r.Start
                    f = True
                End If
                WordDoc.Range(r.Start + 11, r.End - 9).Copy
                Range("C4").Select
                ActiveSheet.Paste
 
                Set r = WordDoc.Range(r.End, r.End)
            Else
 
                Exit Do
            End If
        End With
    Loop
Как совместить это код и код который вы написали, чтобы после того как макрос находит в папке word файл с таким же именем как и значения ячейки из столбца B, он открывал его, копировал нужное слово, вставлял скопированное из word слово на второй (уже созданный) лист в excel? А если не находит в папке файл с таким же именем, то уведомляет что такого файла нет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.06.2018, 09:44
Помогаю со студенческими работами здесь

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

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

Поиск по содержимому файла
Хотелось сделать так чтобы при если введенный номер в textbox совпадет с тем что есть в txt документе, то в Label вывел сообщение о том,...

Поиск по содержимому файла
Windows 8 не ищет по содержимому файлов *.C, *.CPP и т.п. По содержимому *.txt все норм. Кто знает как решить проблему?

Поиск txt файла по содержимому
Необходимо написать такую программу - пользователь выбирает папку и вводит фразу для поиска, программа находит такой txt файл (первый...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru