fme和python-docx结合实现批量按指定位置插入图片、文本等信息
最近悟空因为项目上的需求,需要批量实现一个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结合实现批量按指定位置插入图片、文本等信息相关推荐
- 用 Python 自动生成 Word 文档并在指定位置插入图片
用Python生成Word文档 在指定位置插入图片 首先当然需要第三方库啦(▽) 天才第一步,第三方的库O(∩_∩)O哈哈~ 参照转发的是这位大佬的博客:https://blog.csdn.net/c ...
- python替换指定位置word图片_用Python在word的指定位置插入图片(使用Python-docx包)...
1 2 首先,本实例是采用java语言的,需要进行xml操作,至于poi,docx4j这些,因为感觉不是文档不太好,要嘛就是操作不方便,而且英文就算了,主要是注释很少,让人云里雾里的.所以,嘿嘿,直接 ...
- java 实现docx文件指定位置插入图片
首先导入需要用到的jar: <dependencies><dependency><groupId>org.apache.poi</groupId>< ...
- python 在表格指定位置插入图片
在表格指定位置插入图片 import xlsxwriter file = '数据' + '.xlsx' # 保存表格名 pic_path = 'image/1.png' # 图片路径 workbook ...
- Word、PPT、PDF 文件怎么批量插入首页、扉页、尾页?怎么在指定位置插入页?
概要:在我们日常办公中,经常会碰到需要给一批 Word 文件批量插入首页或者尾页,或者在指定的位置插入新的页的需求,当然除了 Word,PDF 以及 PPT 也有相同的需求.「我的ABC软件工具箱」就 ...
- Txt、记事本等文本文件怎么批量插入标题?怎么在指定位置插入新的内容?
概要:在我们日常办公中,经常会碰到需要给一批 Txt.Json 或者记事本等各种文本文件批量插入一段新的内容,或者将指定文本文件批量插入一批文本文件中的需求.「我的ABC软件工具箱」就实现了批量在指定 ...
- 如何在Windows cmd上递归删除文件或文件夹?批量删除指定大小的图片文件
如何在Windows cmd上递归删除文件或文件夹? for /r %R in (.gif) do if exist %R (rd /s /q "%R") / q禁用是/否提示 / ...
- 快速批量在工作表插入图片
实例需求:在示例目录中有多个Excel文件,需要在每个文件的全部工作表中快速插入图片,图片文件位于同一目录中,文件名为Chart1.png,代码所在文件"Demo.xlsm"无需插 ...
- 【Python】通过xlsxwriter向excel表格中插入图片、本地超链接
通过python向excel表格中插入图片,且设置图片的本地超链接. 代码亲测可行,python版本为3.6.3 import xlsxwriter# 创建一个新Excel文件并添加一个工作表. wo ...
最新文章
- 潜在狄利克雷分配(LDA,Latent Dirichlet Allocation)模型(三)
- 【原创】CSSOO的思想及CSS框架的应用(未整理完)
- 面试题: 数据库 真实面试题已看1 操作语句 存储过程 挺好 sql语句练习 有用
- OGNL与Struts2标签展示页面(一)
- 通讯http,TCP/IP与socket之间的区别
- 恢复云数据库MySQL的备份文件到自建数据库
- repo/git下载android源码断后重新下载
- 进程与线程的一个简单解释【摘】
- 在FMS服务器端侦听流的发布
- Linux命令之find命令
- Linux下ALSA驱动分析
- 单层感知器神经网络matlab,MATLAB神经网络——单层感知器
- Android APP隐藏图标、无启动界面、进程隐藏的方法
- pycharm的配置——字体
- Hark的数据结构与算法练习之圈排序
- 辨析:分段函数是不是初等函数?
- 记录:mac和win共享磁盘(同一局域网)
- 手机接收机的功能电路(3)---振荡电路、锁相环
- 微型计算机原理第三版考试,微机原理试题及答案
- 手把手教你在linux服务器中部署javaweb项目