|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
||||||
Word Поиск и замена с Wildcard и условием If / Then14.01.2010, 21:21. Показов 8841. Ответов 18
Метки нет (Все метки)
Привет всем, очень нужен модуль для VBA-макроса в MS Word, который бы производил следующие замены в таблице с текстом:
1) Найти в ячейках определенного столбца таблицы предложение с помощью Wildcard find (с подстановочными знаками), т.к. там в середине или перед искомым текстом могут быть названия месяцов и предметов, вместо них, соответственно, "*". Например, Find "*Class2*Student Number Change" 2) Далее, нужно перед этим найденным текстом вставить перевод (не изменяя найденный текст): "Изменение числа студентов в классе№2 / § ". Символ "§" вставляем, чтобы потом использовать его в дополнительной проверке условий: Если этот символ уже есть в строке (ячейке) с найденным текстом, то пропускаем ячейку, т.к. там перевод произведен. Вот что примерно у меня наметилось:
0
|
||||||
| 14.01.2010, 21:21 | |
|
Ответы с готовыми решениями:
18
Пустые ячейки и условие If Not IsEmpty(.Cells(i, 1)) Then |
|
3924 / 925 / 125
Регистрация: 16.04.2009
Сообщений: 1,974
|
||
| 15.01.2010, 20:36 | ||
|
0
|
||
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
|||||||||||
| 16.01.2010, 06:36 | |||||||||||
|
Victor_V_V,
В других столбцах и вообще в документе могут встречаться искомые фразы? У тебя поиск происходит там, где курсор стоит. Надо сначала выделить то, что нашёл.
0
|
|||||||||||
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
||
| 16.01.2010, 15:47 [ТС] | ||
|
А где именно надо вставить .Parent.Select ?
0
|
||
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
||||||
| 16.01.2010, 17:09 | ||||||
|
Victor_V_V,
тогда не нужно просматривать ячейки таблицы, если такого рода информация содержится только в столбцах, где ты ищешь. Веди поиск по всему документу, так будет быстрее (хотя точно не знаю, просто так написал).
0
|
||||||
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
||||||
| 16.01.2010, 22:32 [ТС] | ||||||
|
ok, попробовал вот так сделать, поиск по всему тексту, но вставка текста в конце модуля не производится
![]()
0
|
||||||
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
||||||||||||||||
| 16.01.2010, 23:06 | ||||||||||||||||
|
Victor_V_V
сделай комментарии к своему коду и убери знак переноса на следующую строчку, о котором тебе писали здесь. И нет
Victor_V_V, и вот это что такое?
0
|
||||||||||||||||
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
|||||||||||
| 17.01.2010, 22:20 [ТС] | |||||||||||
|
Busine2009, вот я сделал еще 2 варианта,
первый вариант повторяет поиск бесконечным циклом, но не производит вставку текста
0
|
|||||||||||
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
||||||
| 18.01.2010, 07:45 | ||||||
|
Victor_V_V,
я сейчас тоже не понимаю ничего: выпил 0,5 л балтики 9 и 0,5 л Охоты. У тебя задача искать во всём документе или в определенной таблице? Добавлено через 6 часов 32 минуты Victor_V_V, Вот так попробуй:
0
|
||||||
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
||||||
| 18.01.2010, 15:37 [ТС] | ||||||
|
Busine2009, спасибо огромное, так всё работает, не догадался поставить
0
|
||||||
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
||||||
| 02.02.2010, 06:47 [ТС] | ||||||
|
Опять нужна помощь по макросу для Word:
В 4-м столбце таблицы расположены даты, но цифры стоят после названий месяцев, надо поменять их местами. Этот фрагмент макроса ищет в 4-м столбце таблицы с текстом название месяца с последующей цифрой - датой, потом удаляет название месяца перед цифрами и помещает аналогичное название после цифр (в конце текста данной ячейки таблицы). Вот пример, но тут какая-то ошибка, приводит к бесконечному циклу.
0
|
||||||
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
|
| 02.02.2010, 08:21 | |
|
Victor_V_V,
через parent выделяй. wrap можешь удалить.
0
|
|
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
|||||||
| 03.02.2010, 07:00 [ТС] | |||||||
|
Object doesn't support this property or method
0
|
|||||||
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
|
| 03.02.2010, 08:29 | |
|
Victor_V_V,
я setы вообще не использую и не умею ими пользоваться, расскажи мне, зачем ты это делаешь? Это просто вопрос, а не что-то там.
0
|
|
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
|
| 03.02.2010, 19:54 [ТС] | |
|
Да просто в одном примере было. Иногда использование range удобнее, чем Selection, но наверное не в этом случае...
0
|
|
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
|
| 03.02.2010, 22:04 | |
|
Victor_V_V,
set - это создание объектной переменной. Обоснуй использование set в твоём случае: для чего ты это делаешь? Объектная переменная - это область в оперативной памяти, имеющая имя - аналог файл, находящийся на жёстком диске.
0
|
|
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
||||||
| 06.02.2010, 22:10 [ТС] | ||||||
|
Да ладно, мне на самом деле пофигу что там какие-то областя создаются, у меня памяти много, и я в этом не разбираюсь. В примере было 2 варианта поиска: через select и через range, и я их оба использую как в шаблонах показано.
А тут на самом деле просто точку пропустил в начале строки (.Parent.Select ), так что спасибо! ![]()
0
|
||||||
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
||||||
| 07.02.2010, 07:20 | ||||||
|
Victor_V_V,
Без сетов, но не проверял этот код, т.к.не хочу даже вникать, что ты там ищешь.
1
|
||||||
|
0 / 0 / 0
Регистрация: 14.01.2010
Сообщений: 20
|
|
| 07.02.2010, 16:30 [ТС] | |
|
Busine2009, спасибо
0
|
|
| 07.02.2010, 16:30 | |
|
Помогаю со студенческими работами здесь
19
добавление условия в оператор If then Что означают слова INPUT,THEN и.д Оператор if...then If-Then-Else или Select Case: что предпочтительнее использовать If /Then/Else Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
BOINC: 22 года — и всё ещё работает
Programma_Boinc 12.03.2026
BOINC: 22 года — и всё ещё работает
Дэвид Андерсон написал ретроспективу. Кратко: в 2001 году он ушёл из United Devices, где был CTO, и за несколько месяцев написал ядро BOINC — клиент, сервер,. . .
|
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
На первой гифке отладочные линии отключены, а на второй включены:. . .
|