最近悟空因为项目上的需求,需要批量实现一个word邮件合并的案例,项目要求如下

1、拥有N个图斑编号命名的照片,一个含有属性信息的Excel表格,以及一个模板

当然,按照以前的思维,是可以通过word自带的邮件合并实现的,但是word自带的邮件合并扇出的时候,图片不能有效加载,需要挨个刷新才行,而且还需要另存才能把图片彻底导入到word中,无疑是非常落后的手段。然后我就把思路放在了python自带的邮件合并库mailmarge上面

这边直接上代码

但是需要提前在word中设置好域名

但是我不知道这个库如何插入图片,于是我用正常的邮件合并方式将路径域名放在

图片插入的路径里面,但是我多次尝试后发现双重域,python-mailmarge库无法导入第二重的路径。于是到处查询这个库的用法,最终我上python官网上查询到了搞笑的一幕

好吧,看来这个库的开发者目前没实现这个功能 属实让我无助了起来。

就在到处想办法之时,我想到了python自带的docx库,但是python自带的docx库在pycharm中要实现批量的话,需要大量的循环遍历,还需要用pandas处理原始数据,并且写出来了性能也不是很理想。

最终我又回到了fme,因为fmeobj的特性,在pythoncaller转换器中,输入来的所有要素自动默认遍历,意思是只需要把字段看成一个要素来写代码,是不是就能用docx库实现高阶邮件合并功能了呢

并且还可以用fme提前处理好需要导入的原始数据,带着试一试的心态,最终我还是实现了。这边直接上成果图

果然不出我所料,fme自动实现了遍历,并批量导出了word文档,也成功插入了图片、导入了信息。

总结:fme是一个强大的工具,但是没有自带能读取word数据的模块,也很难实现word的各种操作,但是我发现从2015年的fme安装包开始,就默认安装了python-docx库,我认为这是开发者给需要该功能的用户提供的一个方法,如果光用python就要走很多弯路(每个要素都需要遍历)

光用fme根本无法实现,光用word又 实现不了项目要求。将三者结合起来,互补了互相的短板。或许这就是我启蒙老师给我说的“一切有为法,如梦幻泡影,如露亦如电,应作如是观”吧。

需要源fmw工程文件的小伙伴可以私聊,关注一手,后期会持续更新各种有趣的fme和python玩法,下期可能会更新fme和机器学习相关的内容。

fme和python-docx结合实现批量按指定位置插入图片、文本等信息相关推荐

  1. 用 Python 自动生成 Word 文档并在指定位置插入图片

    用Python生成Word文档 在指定位置插入图片 首先当然需要第三方库啦(▽) 天才第一步,第三方的库O(∩_∩)O哈哈~ 参照转发的是这位大佬的博客:https://blog.csdn.net/c ...

  2. python替换指定位置word图片_用Python在word的指定位置插入图片(使用Python-docx包)...

    1 2 首先,本实例是采用java语言的,需要进行xml操作,至于poi,docx4j这些,因为感觉不是文档不太好,要嘛就是操作不方便,而且英文就算了,主要是注释很少,让人云里雾里的.所以,嘿嘿,直接 ...

  3. java 实现docx文件指定位置插入图片

    首先导入需要用到的jar: <dependencies><dependency><groupId>org.apache.poi</groupId>< ...

  4. python 在表格指定位置插入图片

    在表格指定位置插入图片 import xlsxwriter file = '数据' + '.xlsx' # 保存表格名 pic_path = 'image/1.png' # 图片路径 workbook ...

  5. Word、PPT、PDF 文件怎么批量插入首页、扉页、尾页?怎么在指定位置插入页?

    概要:在我们日常办公中,经常会碰到需要给一批 Word 文件批量插入首页或者尾页,或者在指定的位置插入新的页的需求,当然除了 Word,PDF 以及 PPT 也有相同的需求.「我的ABC软件工具箱」就 ...

  6. Txt、记事本等文本文件怎么批量插入标题?怎么在指定位置插入新的内容?

    概要:在我们日常办公中,经常会碰到需要给一批 Txt.Json 或者记事本等各种文本文件批量插入一段新的内容,或者将指定文本文件批量插入一批文本文件中的需求.「我的ABC软件工具箱」就实现了批量在指定 ...

  7. 如何在Windows cmd上递归删除文件或文件夹?批量删除指定大小的图片文件

    如何在Windows cmd上递归删除文件或文件夹? for /r %R in (.gif) do if exist %R (rd /s /q "%R") / q禁用是/否提示 / ...

  8. 快速批量在工作表插入图片

    实例需求:在示例目录中有多个Excel文件,需要在每个文件的全部工作表中快速插入图片,图片文件位于同一目录中,文件名为Chart1.png,代码所在文件"Demo.xlsm"无需插 ...

  9. 【Python】通过xlsxwriter向excel表格中插入图片、本地超链接

    通过python向excel表格中插入图片,且设置图片的本地超链接. 代码亲测可行,python版本为3.6.3 import xlsxwriter# 创建一个新Excel文件并添加一个工作表. wo ...

最新文章

  1. 潜在狄利克雷分配(LDA,Latent Dirichlet Allocation)模型(三)
  2. 【原创】CSSOO的思想及CSS框架的应用(未整理完)
  3. 面试题: 数据库 真实面试题已看1 操作语句 存储过程 挺好 sql语句练习 有用
  4. OGNL与Struts2标签展示页面(一)
  5. 通讯http,TCP/IP与socket之间的区别
  6. 恢复云数据库MySQL的备份文件到自建数据库
  7. repo/git下载android源码断后重新下载
  8. 进程与线程的一个简单解释【摘】
  9. 在FMS服务器端侦听流的发布
  10. Linux命令之find命令
  11. Linux下ALSA驱动分析
  12. 单层感知器神经网络matlab,MATLAB神经网络——单层感知器
  13. Android APP隐藏图标、无启动界面、进程隐藏的方法
  14. pycharm的配置——字体
  15. Hark的数据结构与算法练习之圈排序
  16. 辨析:分段函数是不是初等函数?
  17. 记录:mac和win共享磁盘(同一局域网)
  18. 手机接收机的功能电路(3)---振荡电路、锁相环
  19. 微型计算机原理第三版考试,微机原理试题及答案
  20. 手把手教你在linux服务器中部署javaweb项目

热门文章

  1. MYSQL索引底层原理
  2. 【Wiki】XWiki安装教程_War包版本
  3. MATLAB/Simulink电力系统与仿真,第四章的2机5节点潮流计算模型建模经验
  4. 修复登录接口社区论坛微信小程序源码下载-支持多种发帖模式超强社区
  5. 技术贴,关于Rhino各类版本无法打开问题
  6. 脚踏实地的好好学习深度学习 笔记一 线性回归
  7. Linux jar包 后台运行命令
  8. oracle 表空间的数据文件丢失或损坏的恢复
  9. MATLAB R2016a实现三方演化博弈
  10. 存款准备金率的意义,如何获取