Mathtype公式自动转Word自带公式

本文介绍了如何使用Mathtype公式自动转换为Word中的公式,包括ALT+编号输入、Mathtype至OfficeMath的转化问题,以及利用VBA编写代码实现批量转换的过程,包括失败处理和提示用户是否重复运行的逻辑。
摘要由CSDN通过智能技术生成


前言/word技巧

  • word公式
    • 用ALT+=号可以输入简单latex显示公式;复杂度,需要引入latex包的不行;显示不出来的话按一下enter键就出来了,需要手动删除换行
    • 公式末尾加#(1)会显示编号(1);不会自动更新编号
  • Mathtype公式
    • 选择公式,右键;对象,转化为office math,可以变为word公式
    • 在我的电脑上无效;可能是因为word版本原因(需要2016甚至更新);可能是因为mathtype是破解的
  • AxMath
    • 可以直接转word公式
    • 没有破解版仅仅找到32位的;我的64位不能用
    • 费用36元,不想给
  • GrandEq
    • 可以latex、word、pdf、公式互转
    • 巨贵,买不起
    • 安装了,发现没有10次免费试用了

探索过程

  • 基于各种原因,转换失败;

  • 参考博客,发现可以:

    • 通过mathtype全文公式转化为arc语句,再手动复制粘贴转为word公式
    • 为了自动化,可以再编写vba命令,自动完成

参考资料(有效与无效)


全自动方案/代码/教程

  • 转换公式为attr代码;记得勾选包括译者名字
    在这里插入图片描述

  • 转化结果,非常长; 观察首尾译者名字,每个人的不太一样
    在这里插入图片描述

  • word中编写代码

    • Alt+F11
    • 插入,模块
      在这里插入图片描述
  • 粘贴代码;修改自这里

Sub MathML2OMML(k As Integer)
'用k记录总的转换成功数。
On Error GoTo ErrorHandler   ' 启用错误处理
Application.ScreenUpdating = False '关闭屏幕刷新
Dim i, j, m As Integer
i = 0  '记录转换的公式总数,失败的也会记录在内
j = 0  '防止死循环用的,记录错误次数
m = 0  '记录转换失败次数
 
With Selection.Find   '设置查找表达式,查找转换后的MathML代码
    .ClearFormatting
    .Replacement.ClearFormatting
    .Text = "\<\!-- MathType\@Translator?*End\@5\@5\@ --\>" '通配符选择公式,注意mathtype转换时,最后两个复选框要选中;每个人的开头不同,修改成你自己的;?*是通配符
    .Replacement.Text = ""
    .Forward = True
    .Wrap = wdFindStop
    .Format = False
    .MatchWildcards = True
 
    Selection.SetRange 0, 0 '回到文首
 
    Do While .Execute
        With Selection
            .Copy '复制MathML代码
            .PasteAndFormat (WdRecoveryType.wdFormatPlainText) '无格式粘贴MathML代码
        End With
        i = i + 1 '转换公式数+1
    Loop
End With
 
Application.ScreenUpdating = True '开启屏幕刷新
'MsgBox "新转换成功" & i & "个公式,如数字偏大,建议重复运行"
 
k = k + i - m
 
If (m > 10 And i - m > 0) Then
       Call MathML2OMML(k)  '只要失败数超过10,且有新成功的,就重复运行,
 
Else
    a = MsgBox("最后一次运行转换失败" & m & "个公式,是否重复运行", vbYesNo)
   
    If a = vbYes Then
        Call MathML2OMML(k)  '选择是,则重复运行
    Else
        MsgBox ("共新转换成功" & k & "个公式")
        Exit Sub
    End If
 
End If
 
'Exit Sub
 
ErrorHandler:       ' 错误处理
  j = j + 1       '错误出现次数加一
   If j < 100 Then
    Resume       ' 100次以内直接忽略错误,继续执行
   Else
     j = 0    '防止死循环,跳过一行后,继续执行知道100次错误出现
     'MsgBox "运行出错"
     m = m + 1
     Resume Next
   End If
  
 
End Sub
 
Sub 公式转换()
Call MathML2OMML(0)
End Sub

  • 按F5运行;成功转换98%的公式;剩下的异常的手动调调
  • 注意通配符头尾根据自己的译者名字修改;不然搜索不到MathML代码
    在这里插入图片描述
    在这里插入图片描述
  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 `MathType` 官方提供的 `MTX2MML.js` 脚本来将 `MathType` 公式转换为 `MathML2.0` 格式,具体步骤如下: 1. 首先,确保你已经安装了 `MathType` 软件,并且安装了 `MathType` 的浏览器插件。 2. 打开你的 `Word` 文档,点击 `文件` -> `另存为`,将文件类型设置为 `XML`,然后保存文件。 3. 打开保存的 `XML` 文件,找到包含 `MathType` 公式的部分,通常会以 `<w:instrText>` 开头,以 `</w:instrText>` 结尾。 4. 将 `MathType` 公式的 `id` 属性和 `equation` 属性分别提取出来,并将它们作为参数传递给 `MTX2MML.js` 脚本。你可以使用以下代码来实现: ```javascript // 假设你已经将 XML 文件的内容读取到了 `xmlStr` 变量中 // 正则表达式用于提取 MathType 公式的 id 和 equation var regExp = /<w:instrText.*?xml:id="(.*?)".*?MathType.*?Equation="(.*?)"/g; var matchArr = []; var match; while ((match = regExp.exec(xmlStr)) != null) { matchArr.push(match); } // 遍历每个匹配到的 MathType 公式,将其转换为 MathML2.0 格式 for (var i = 0; i < matchArr.length; i++) { var id = matchArr[i][1]; var equation = matchArr[i][2]; // 调用 MTX2MML.js 脚本进行转换 var mathML = MTX2MML.ConvertEquation(id, equation); // 将 MathML2.0 格式的公式替换原来的 MathType 公式 xmlStr = xmlStr.replace('<w:instrText xml:id="' + id + '"', '<w:instrText xml:id="' + id + '">' + mathML); } ``` 5. 最后,将处理后的 `XML` 文件保存并重命名为 `.docx`,用 `Word` 打开即可查看转换后的公式。 需要注意的是,使用 `MTX2MML.js` 脚本需要先加载 `MathType` 的浏览器插件,否则会报错。此外,该脚本只适用于将 `MathType` 公式转换为 `MathML2.0` 格式,如果你的 `XML` 文件中包含其他类型的公式,需要使用相应的转换工具来处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值