In this article I will explain how you can create equations using VBA for word.
–
Step 1, Getting the Text String Associated with the Equation:
The first step for creating an equation in VBA for word is to determine the text string associated with that equation. You might not have noticed but equations in word are a basic text string. For example take a look at the the equation below:
If you copy the equation and paste it in a notepad this is what you get:
The text in the notepad might seem like nonsense, but the word editor understands this. In order to create equations in word using VBA, we too will have the create the text string above.
The text above can be converted back to a word equation by following the steps below:
Step 1: Copy the text in the notepad editor and paste it in an empty word document:
Step 2: Select the text in the word document and click on the “Insert Equation” button on the “Insert” tab
Step 3: Choose professional View:
Result:
As you can see the equation was created from the text string in the notepad file. So basically we need to be able to generate the text string in the notepad file to create the equation in word.
I will explain this in more detail in the following sections.
–
Step 2:
The next step for creating an equation is to move the cursor to the location you want to insert the equation.For more information about moving the cursor around the document please see the links below:
- Word VBA Using Bookmarks to Move the Cursor
- Word VBA, Move Cursor to Start of Document
- Word VBA, Move Cursor to End of Document
- Word VBA, Move Cursor to End of Line
- Word VBA, Move Cursor to Start of Line
- Word VBA, Go to Specific Line
–
Creating Simple Equations :
Equations can be made using the code below:
Sub Example1()
Dim objRange As Range
Set objRange = Selection.Range
objRange.Text = "y = x^2+1"
Call OMaths.Add(objRange)
End Sub
Note: If you want to keep reference to the newly created equation you could use the code below. You could then change the display to professional so it looks like a real equation:
Sub Example2()
Dim objRange As Range
Dim objOMath As OMath
Set objRange = Selection.Range
objRange.Text = "y = x^2+1"
Set objOMath = OMaths.Add(objRange).OMaths.Item(1)
objOMath.BuildUp
End Sub
–
Creating Complex Equations:
For more complex equations you can’t simply paste the text string in the VBA editor. For example lets say we want to create the equation explained at the start of the post. The first step would be to replace the text :
- “y = x^2+1”
with
- “f(x)=a_0+∑_(n=1)^∞▒(a_n cos〖nπx/L〗+b_n sin〖nπx/L〗 ) “
But this is what will happen if we try to make this replacement:
Sub Example1()
Dim objRange As Range
Set objRange = Selection.Range
objRange.Text = _
"f(x)=a_0+?_(n=1)^8n(a_n cos??npx/L?+b_n sin??npx/L? ) "
Call OMaths.Add(objRange)
End Sub
As you can see a lot of the characters are not recognized by the VBA editor and are replaced by a “?” character. The solution to this is explained in the steps below:
Step 1: Break the text string into different segments, separating the “?” characters:
"f(x)=a_0+" + ? + "_(n=1)^8n(a_n cos"+ ?? + _
"npx/L" + ?+ "+b_n sin' + ?? + "npx/L" +? +" ) "
For more information about concatenating strings please see the link below:
- VBA Excel String Processing and Manipulation
Step 2: Find the unicode value associated with the missing characters. The missing characters are:
- ∑
- 〖
- 〗
- ▒
I have written a program which returns the unicode value associated with characters. You can download the program at the link below and use it to find the unicode values associated with each of the characters above:
- VBA Get Characters Unicode Value
Step 3: Replace the “?” characters with the
function. The ChrW()
function receives as input a unicode value and returns the character associated with it:ChrW()
Sub Example3()
Dim objRange As Range
Dim objOMath As OMath
Set objRange = Selection.Range
objRange.Text = _
"f(x)=a_0+" + ChrW(8721) + "_(n=1)^8" + ChrW(9618) + _
"(a_n cos" + ChrW(12310) + "npx/L" + ChrW(12311) + _
"+b_n sin" + ChrW(12310) + "npx/L" + ChrW(12311) + " )"
Set objOMath = OMaths.Add(objRange).OMaths.Item(1)
objOMath.BuildUp
End Sub
Result:
You can download the file and code related to this article from the link below:
- Create Word Equation.docm
See also:
- Word VBA Equations Linear/Professional Display
- Microsoft (MSDN) OMath Object (Word)
If you need assistance with your code, or you are looking for a VBA programmer to hire feel free to contact me. Also please visit my website www.software-solutions-online.com
Hi. Помогите пожалуйста, ни как не получается вставить формулу в вордовский документ.
В VBA формула вставляется так: (формула x=1/2)
Selection.Fields.Add Range:=Selection.Range, Type:=wdFieldEmpty, PreserveFormatting:=False
Selection.TypeText Text:=»[COLOR=»Blue»]EQ x=f(1;2)[/COLOR]»
Selection.Fields.Update
Пробую на С++Buildere
Variant Word=CreateOleObject(«[COLOR=»Blue»]Word.Application[/COLOR]»);
Word.OlePropertySet(«[COLOR=»Blue»]Visible[/COLOR]»,1);
Variant Documents=Word.OlePropertyGet(«[COLOR=»Blue»]Documents[/COLOR]»);
Documents.OleProcedure(«[COLOR=»Blue»]Add[/COLOR]»);
Variant ActiveDocument=Word.OlePropertyGet(«[COLOR=»Blue»]ActiveDocument[/COLOR]»);
Variant Tables=ActiveDocument.OlePropertyGet(«[COLOR=»Blue»]Tables[/COLOR]»);
ActiveDocument.OleProcedure(«[COLOR=»Blue»]Select[/COLOR]»);
Variant Selection = Word.OlePropertyGet(«[COLOR=»Blue»]Selection[/COLOR]»);
Selection.OleProcedure(«TypeText», «[COLOR=»Blue»]EQ x=f(1;2)[/COLOR]»);
Вместо формулы вставляется текст, помогите разобраться.
Возможно есть другие возможности, советуйте!
За ранее, Спасибо!
0 / 0 / 0 Регистрация: 04.05.2013 Сообщений: 49 |
|
1 |
|
14.01.2018, 21:32. Показов 2994. Ответов 16
Язык программирования Visual Basic Net. Формула любого вида (старый или новый формат). P.s. задача, в принципе, следующая: есть програмка, которая производит расчет. Хочу при помощи кода автоматизировать вывод результатов расчета в конечный документ для пользователя. Для этого создам шаблон и в него вставлять рассчитанные значения
0 |
99 / 94 / 23 Регистрация: 30.08.2015 Сообщений: 457 |
|
15.01.2018, 13:21 |
2 |
Для этого создам шаблон а что если в шаблоне вместо значений подставить идентификационный набор символов и потом искать их и заменять на соответствующие им значения ?
0 |
miki2343 0 / 0 / 0 Регистрация: 04.05.2013 Сообщений: 49 |
||||
15.01.2018, 17:43 [ТС] |
3 |
|||
Кстати, как вариант. Добавлено через 3 часа 41 минуту Вопрос теперь в другом
Этот код ошибочный, а именно он меняет только одно слово «мама» на «заменено1». Понимаю, что надо прописать ReplaceAll, но проискав по инету, выдает все ошибки в коде.
0 |
99 / 94 / 23 Регистрация: 30.08.2015 Сообщений: 457 |
|
15.01.2018, 17:56 |
4 |
miki2343, зачем вам Visual Basic? Добавлено через 15 секунд
0 |
0 / 0 / 0 Регистрация: 04.05.2013 Сообщений: 49 |
|
15.01.2018, 18:09 [ТС] |
5 |
Прошу прощения — неверный тег при оформлении этого поста
0 |
densy 99 / 94 / 23 Регистрация: 30.08.2015 Сообщений: 457 |
||||
15.01.2018, 18:10 |
6 |
|||
Сообщение было отмечено miki2343 как решение Решение
1 |
miki2343 0 / 0 / 0 Регистрация: 04.05.2013 Сообщений: 49 |
||||
15.01.2018, 18:29 [ТС] |
7 |
|||
Немножко Ваш код изменил, для удобства чтения в Vb.net.
0 |
densy 99 / 94 / 23 Регистрация: 30.08.2015 Сообщений: 457 |
||||
15.01.2018, 18:47 |
8 |
|||
остается только сохранить результат
Добавлено через 13 минут
0 |
miki2343 0 / 0 / 0 Регистрация: 04.05.2013 Сообщений: 49 |
||||||||||||
15.01.2018, 19:10 [ТС] |
9 |
|||||||||||
Лучше так А то шаблон испортим
А это если еще и док закрыть (правда тогда зачем его показывать вначале))
Добавлено через 17 минут Итак:
0 |
ovva 4278 / 3417 / 827 Регистрация: 02.02.2013 Сообщений: 3,308 Записей в блоге: 2 |
||||
15.01.2018, 19:21 |
10 |
|||
densy, если вы добавили ссылку на Office.Interop, то нет никакой необходимости использовать CreateObject(«Word.Application») (используется при т.н. поздней привязке).
1 |
0 / 0 / 0 Регистрация: 04.05.2013 Сообщений: 49 |
|
15.01.2018, 19:34 [ТС] |
11 |
Я ошибся. Неправильно указал ссылку Office — не катит
0 |
0 / 0 / 0 Регистрация: 04.05.2013 Сообщений: 49 |
|
25.02.2018, 08:43 [ТС] |
12 |
Не хочется новую тему создавать.
0 |
Юпатов Дмитрий 1706 / 1194 / 227 Регистрация: 23.12.2010 Сообщений: 1,526 |
||||||||
25.02.2018, 23:39 |
13 |
|||||||
А то шаблон испортим а чтоб шаблон не испортить, надо не ОТКРЫВАТЬ его, а СОЗДАВАТЬ НОВЫЙ ДОКУМЕНТ на основе имеющегося файла:
меняем на
ну а если метод add вызвать так: add() — будет создан документ на основе шаблона по-умолчанию (обычно это Normal.dot)
0 |
15 / 13 / 6 Регистрация: 13.03.2013 Сообщений: 130 |
|
26.02.2018, 19:59 |
14 |
Как заполнять таблички — знаю. а можно поделиться знаниями?)))
0 |
0 / 0 / 0 Регистрация: 04.05.2013 Сообщений: 49 |
|
26.02.2018, 20:07 [ТС] |
15 |
Заполнение таблицы Word документа — здесь есть как добавлять строки. А так полно информации по работе с Word таблицами. Или спросите более точно тогда, думаю или я или другие более грамотные ответят
0 |
15 / 13 / 6 Регистрация: 13.03.2013 Сообщений: 130 |
|
26.02.2018, 20:10 |
16 |
Но, на мой взгляд, выше описанный способ очень неплох, т.к. создаете шаблон, а потом просто меняете в нем определенные вещи. с заменой всё ясно
0 |
Юпатов Дмитрий 1706 / 1194 / 227 Регистрация: 23.12.2010 Сообщений: 1,526 |
||||
27.02.2018, 10:19 |
17 |
|||
вопрос скорее как добавлять новые строки в таблицу
это из VBA — вставляет новую строку в конец первой таблицы в документе.
0 |
Автор Илья Муромец, 16 февраля 2016, 16:51
Илья Муромец
- гость
- Записан
В документе есть текст и несколько уравнений (формул). Как из VBA последовательно выделить каждую формулу? Как понимаю работать надо через Selection.OMaths.Item(1), но выдается сообщение «Запрашиваемый номер семейства не существует».
Администратор
- Administrator
- Сообщения: 2,254
- Записан
Создайте новый пустой ворд-файл и вставьте туда одну формулу и выложите этот файл на форуме.
Это нужно, чтобы понимать, о каких формулах вы пишите.
Или если по каким-то причинам вы не можете выложить файл, то напишите, как создаёте формулу, а именно, куда щёлкаете, чтобы вставить формулу.
Илья Муромец
- гость
- Записан
Вот
[вложение удалено администратором]
Администратор
- Administrator
- Сообщения: 2,254
- Записан
Selection работает двумя способами:
- если выделение в виде мигающего курсора;
- если что-то выделено.
Используя «Selection.OMaths.Item(1)» вы говорите макросу, что хотите работать с формулами, которые находятся или рядом с курсором, или которые находятся в выделенном фрагменте.
Но в задании вы пишите, что вам нужно работать с формулами в документе, а не в выделении.
Значит используйте так:
ActiveDocument.OMaths.Item(1)
Илья Муромец
- гость
- Записан
Большое спасибо! Очень помогли!
- Форум по VBA, Excel и Word
-
►
Word -
►
Макросы в Word -
►
Word VBA: работа с объектом Формула
Содержание
- 1 Assigns the values 101 to 200 to the range B1:Bnd again does it more efficiently than a For…Next loop
- 2 Create a set of related formulas in a column: use a looping structure to iterate through the cells that receive the formula
- 3 Fill formula to cell
- 4 Inserts a formula in cell A11 of a worksheet that calculates the sum of the values in the range A2:A10 using the Excel application»s SUM function
- 5 Is active cell empty
- 6 The Evaluate method can also be used with arrays.
- 7 Two ways you can use Evaluate to generate a reference to a Range object, and assign a value to that object
- 8 Use Copy and Paste or AutoFill functions
- 9 Use [] to evaluate formula
Assigns the values 101 to 200 to the range B1:Bnd again does it more efficiently than a For…Next loop
<source lang="vb">
Sub main()
[B1:B100] = [ROW(101:200)]
End Sub
</source>
Create a set of related formulas in a column: use a looping structure to iterate through the cells that receive the formula
<source lang="vb">
Sub formula()
Dim formulaString As String Dim I As Integer Cells(1, "B").Value = Cells(1, "A").Value For I = 2 To 10 formulaString = "=A" & Trim(str(I)) & "+B" & Trim(str(I - 1)) Cells(I, "B").formula = formulaString Next I
End Sub
</source>
Fill formula to cell
<source lang="vb">
Sub AddWatch()
With Application .Range("A1").Formula = 1 .Range("A2").Formula = 2 .Range("A3").Formula = "=Sum(A1:A2)" .Range("A3").Select .Watches.Add Source:=ActiveCell End With
End Sub
</source>
Inserts a formula in cell A11 of a worksheet that calculates the sum of the values in the range A2:A10 using the Excel application»s SUM function
<source lang="vb">
Sub formal()
Dim formulaString As String formulaString = "=SUM($A$2:$A$10)" Cells(11, "A").Formula = formulaString
End Sub
</source>
Is active cell empty
<source lang="vb"> Sub IsActiveCellEmpty() Dim sFunctionName As String, sCellReference As String sFunctionName = "ISBLANK" sCellReference = ActiveCell.Address MsgBox Evaluate(sFunctionName & "(" & sCellReference & ")") End Sub </source>
The Evaluate method can also be used with arrays.
<source lang="vb">
Sub short()
vRowArray = [ROW(101:200)]
End Sub
</source>
Two ways you can use Evaluate to generate a reference to a Range object, and assign a value to that object
<source lang="vb">
Sub evalDemo()
Evaluate("A1").value = 10 [A1].value = 10
End Sub
</source>
Use Copy and Paste or AutoFill functions
<source lang="vb">
Sub autoFill()
Dim formulaString As String Dim I As Integer Cells(1, "B").Value = Cells(1, "A").Value formulaString = "=A2+B1" Cells(2, "B").formula = formulaString
End Sub
</source>
Use [] to evaluate formula
<source lang="vb">
Sub isBlank()
MsgBox [ISBLANK(A1)]
End Sub
</source>