news 2026/6/10 2:31:18

xhEditor粘贴MathType公式转MathML

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
xhEditor粘贴MathType公式转MathML

(扶了扶眼镜,敲着机械键盘开始码字)各位老板,作为山西前端界的一股泥石流,今天给大家表演个"如何在680元预算内实现文档自由"的绝活!

先甩个前端Vue3插件包(附赠React版兼容补丁):

// XhEditorPlugin.jsexportdefault{install(app){constinitXhEditor=(editor)=>{// 添加文档导入按钮editor.addButton('docImport',{title:'文档导入',icon:'📎',onclick:()=>{constinput=document.createElement('input')input.type='file'input.accept='.docx,.xlsx,.pptx,.pdf'input.onchange=async(e)=>{constfile=e.target.files[0]constformData=newFormData()formData.append('doc',file)// 调用后端解析接口constres=awaitaxios.post('/api/doc-parse',formData)// 插入处理后的HTMLeditor.insertHTML(res.data.content)// 自动上传图片到服务器res.data.images.forEach(img=>{constform=newFormData()form.append('image',img.blob)axios.post('/api/upload',form).then(r=>{editor.insertHTML(``)})})}input.click()}})// 监听Word粘贴事件editor.on('paste',(e)=>{constitems=(e.clipboardData||e.originalEvent.clipboardData).itemsfor(letitemofitems){if(item.type.startsWith('image/')){constblob=item.getAsFile()constform=newFormData()form.append('image',blob)axios.post('/api/upload',form).then(r=>{editor.insertHTML(``)})}}})}app.config.globalProperties.$xhEditor={init:initXhEditor}}}

后端C#版(ASP.NET Core版):

[ApiController][Route("api/doc-parse")]publicclassDocParseController:ControllerBase{[HttpPost]publicasyncTaskParseDocument(IFormFiledoc){// 文档解析核心代码(开源库组合拳)varresult=newDocumentParser().Parse(doc.OpenReadStream(),doc.FileName);// 处理公式转换result.Content=Regex.Replace(result.Content,@"(\$\$.+?\$\$)",m=>{varlatex=m.Value.Replace("$$","");return$"{LatexToMathML(latex)}";});// 返回处理后的内容returnOk(new{content=result.Content,images=result.Images.Select(img=>new{name=img.FileName,url=$"/uploads/{Guid.NewGuid()}{Path.GetExtension(img.FileName)}"})});}privatestringLatexToMathML(stringlatex){// 调用开源转换库(推荐使用MathJax.NET)usingvarconverter=newMathJaxConverter();returnconverter.Convert(latex);}}

(突然神秘兮兮)关于那个emz/wmz格式的公式图片,这里有个祖传偏方:

  1. 用Apache POI提取PPT中的公式
  2. 通过ImageMagick转成PNG
  3. 用OpenCV做锐化处理
  4. 最后用Tesseract OCR识别公式内容

(突然拍桌)但最骚的是微信公众号内容导入!直接祭出这个神器:

// 微信公众号内容抓取functionparseWechatContent(html){constparser=newDOMParser()constdoc=parser.parseFromString(html,'text/html')// 提取正文constcontent=doc.querySelector('#js_content').innerHTML// 处理微信特色样式returncontent.replace(/`]*)>/g,'').replace(/<\/section>/g,'')}

(突然正经)关于预算控制,给大家算笔明白账:

  1. 开源库组合(Mammoth.js + SheetJS + PDF.js)→ 0元
  2. 阿里云OSS学生认证(6个月免费)→ 0元
  3. 人工成本(用爱发电)→ 0元
  4. 群内红包基金(薅羊毛指南)→ 见群公告

(突然掏出手机)加群暗号"山西刀削面",进群即送:

  1. 价值99元的《Word公式转换避坑指南》
  2. 独家整理的《政府网站样式兼容性测试报告》
  3. 群主私藏的《甲方需求翻译词典》

最后透露个暴富秘诀:咱们这个插件包已经支持以下变现姿势

  1. 卖给教育局(每个学校需求量极大)
  2. 卖给科研机构(公式转换刚需)
  3. 卖给政府网站(无障碍阅读要求)
  4. 卖给培训机构(题库导入神器)

(突然压低声音)现在进群的前100名,送价值连城的《如何让甲方主动加预算》话术模板!错过再等一年!

代码仓库:https://github.com/shanxi-fe/doc-import-plugin
(突然发现预算超了5元)咳咳…这个…大家众筹一下服务器费用?

将插件目录复制到项目中

引入插件文件

定义插件图标

初始化插件

在工具栏中添加插件按钮

效果

编辑器

导入Word文档,支持doc,docx

导入Excel文档,支持xls,xlsx

粘贴Word

一键粘贴Word内容,自动上传Word中的图片,保留文字样式。

Word转图片

一键导入Word文件,并将Word文件转换成图片上传到服务器中。

导入PDF

一键导入PDF文件,并将PDF转换成图片上传到服务器中。

导入PPT

一键导入PPT文件,并将PPT转换成图片上传到服务器中。

上传网络图片

一键自动上传网络图片,自动下载远程服务器图片,自动上传远程服务器图片

下载示例

点击下载完整示例

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/8 19:11:46

超越“双重优越感”:AI元人文构想作为文明对话新语法

超越“双重优越感”&#xff1a;AI元人文构想作为文明对话新语法笔者&#xff1a;岐金兰摘要本文系统阐述了AI元人文构想&#xff0c;以应对传统“价值对齐”范式在智能时代面临的静态性与简化论困境。该构想以“意义行为原生论”为哲学基石&#xff0c;主张价值在具体行为互动…

作者头像 李华
网站建设 2026/6/4 15:30:43

Total-Text弯曲文本挑战:HunyuanOCR对非矩形区域的处理

HunyuanOCR如何破解弯曲文本识别难题 在文档图像处理领域&#xff0c;一个看似简单却长期困扰工程师的问题是&#xff1a;为什么一张带有弧形标题的包装图片&#xff0c;传统OCR总是“读歪”甚至漏掉整段文字&#xff1f; 这背后并非模型“看不见”&#xff0c;而是架构本身的局…

作者头像 李华
网站建设 2026/5/31 14:49:31

损失函数组合设计:各子任务权重分配的优化策略

损失函数组合设计&#xff1a;各子任务权重分配的优化策略 在当今多模态AI系统快速演进的背景下&#xff0c;端到端模型正悄然重塑传统OCR的技术格局。过去那种“先检测、再识别、最后抽取”的级联流程&#xff0c;虽然逻辑清晰&#xff0c;却饱受误差累积、部署复杂和跨语言支…

作者头像 李华
网站建设 2026/6/6 15:00:26

并发请求限制调整:优化HunyuanOCR vLLM推理服务器性能

并发请求限制调整&#xff1a;优化HunyuanOCR vLLM推理服务器性能 在AI模型日益走向生产落地的今天&#xff0c;一个常见的尴尬局面是&#xff1a;实验室里精度惊艳的大模型&#xff0c;一旦上线就频繁崩溃——尤其是面对真实用户并发上传图像时&#xff0c;GPU显存瞬间飙红&am…

作者头像 李华
网站建设 2026/6/7 14:13:40

知识蒸馏技术运用推测:小模型达到SOTA的背后秘密

知识蒸馏技术运用推测&#xff1a;小模型达到SOTA的背后秘密 在当今AI模型“军备竞赛”愈演愈烈的背景下&#xff0c;百亿、千亿参数的大模型频频刷新各项任务榜单。然而&#xff0c;当我们将目光从实验室转向真实业务场景——尤其是移动端、边缘设备和实时服务系统时&#xff…

作者头像 李华
网站建设 2026/6/10 11:32:57

大模型面试之手写Multi-Head Attention

1. 多头注意力机制(MHA)回顾 Multi-Head Attention 是 Transformer 架构的核心组件。它的目标是通过多个注意力头并行计算,让模型能从不同子空间捕捉信息。 在面试中,如果让你手写实现,一般是基于 PyTorch。 我们直接上手代码: import torch import torchnn as nn im…

作者头像 李华