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

Поиск и замена в зависимости от впередиидущей цифры

21.05.2013, 08:51. Показов 1098. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Собственно сабж.
Есть текст: "Всего было 1024 коней." Нужно чтобы скрипт из этого находил "4 коней." и менял на "4 коня".
Есть код, но он работает криво, считая впередиидущую цифру 0 либо null:
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
Sub ak_Kones()
Dim sText As Range
Dim vFindText As Variant
Dim vReplText As Variant
Dim i As Long
Set sText = ActiveDocument.Range
vFindText = Array("^? коней.")
 
InputText = vFindText(i)
Set RegEx = CreateObject("VBScript.RegExp")
 With RegEx
 .Global = True
 .Pattern = "[^\dA-Za-z+]"
 Summa = .Replace(InputText, "")
 End With
 
PartNum = Int(Val(Summa))
If PartNum = 0 Then
    NumStr = NumStr & "коней"
  Else
    ' выделение цифры единиц
    NumTMP = PartNum
    Select Case NumTMP
    Case 1
      If PartNum <> 11 Then
        NumStr = NumStr & "конь"
      Else
        NumStr = NumStr & "коней"
      End If
      Case 2, 3, 4
        If (PartNum < 5) Or (PartNum > 14) Then
          NumStr = NumStr & "коня"
        Else
          NumStr = NumStr & "коней"
        End If
      Case Else
        NumStr = NumStr & "коней"
    End Select
  End If
 
vReplText = Array(NumStr)
 
With sText.Find
.ClearFormatting
.Replacement.ClearFormatting
.Forward = True
.Wrap = wdFindStop
.MatchWholeWord = True
.MatchWildcards = False
.MatchSoundsLike = False
.MatchAllWordForms = False
.Format = True
.MatchCase = True
For i = LBound(vFindText) To UBound(vFindText)
.Text = vFindText(i)
.Replacement.Text = vReplText(i)
.Execute Replace:=wdReplaceAll
Next i
End With
End Sub
Требуется помощь знающих.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.05.2013, 08:51
Ответы с готовыми решениями:

Поиск и замена одной цифры в массиве
Здравствуйте уважаемые форумчане. В файле есть строка вида - Data value=&quot;00000000 00000000&quot; Нужно проверить последнюю цифру и...

Поиск слова, замена букв в зависимости от того есть ли они в слове или нет
Задачка непростая. Итак, вот что надо сделать: программа должна в вводимом тексте искать каждое 5 слово и заменять только одну...

Замена последней цифры на значение наименьшей цифры в записи числа N
Ошибка в задании Условие:Дано натуральное число N. Получить новое число М, которое образуется из числа N путем замены последней цифры на...

2
21.05.2013, 15:55

Не по теме:

а почему у тебя всего одно сообщение, но рейтинг уже -107? Когда успели? :D

0
0 / 0 / 0
Регистрация: 21.05.2013
Сообщений: 3
21.05.2013, 18:50  [ТС]
Вероятно, заминусовавшие либо усмотрели в теме повтор (поиск ничего не дал), либо нашли форму вопроса неподходящей.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.05.2013, 18:50
Помогаю со студенческими работами здесь

Поиск и замена с пропуском первой замены. Замена начиная со второго значения
Добрый день. Я прогнал mysql базу такой заменой. UPDATE post SET pagetext = CONCAT (substring(pagetext, 1,...

Адаптивная замена CSS в зависимости от разрешения
Написал небольшой скриптик на js для подмены таблицы стилей в зависимости от ширины окна: function changeCss() { var w = ...

PHP - замена слова в зависимости от УРЛ
Доброго времени суток. Подскажите, как сделать через php подмену слова в зависимости от урл. К примеру есть предложение: Услуги...

Замена символа в зависимости от случайного значения
У меня имеется массив, состоящий из двоичных чисел, дополненных до 5 знаков. Мне надо по нему пройтись, чтобы на каждой итерации...

Замена в регулярных выражениях в зависимости от группы
Вчера целый вечер гуглил, а сегодня читал книгу, но так пока и не смог понять, как произвести замену в зависимости от группы, в которую...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru