Python读取docx内容,并写入excel中

本人Python新手,以下用词可能有不准确的地方,请大家指出,目的是为了让更多遇到相同问题的人更好的理解,谢谢!

硬件环境:macOS Catalina 10.15

软件环境:Python3.7.6和Python3.6

前提:

年初,很多公司可能要求写年终总结。本人也没法逃避,把年终总结拼拼凑凑,搞定后也算是完成了开年的第一个任务。

提交完后的某一天,公司人事来到工位旁,面带微笑。

我内心高兴的P.S.以为:难道我要被优化了(互联网圈的朋友应该都懂)?终于公司要对我这过气的程序员下手了!正打算拿起手机打开录像功能时(模仿某某车公司员工),人事的第一句话我的心就凉凉了。

“帮个忙呗!”

“公司的总结是word,没人一份,想要汇总成一个excel中。”

“抽时间搞一下就行,我不急着用!”

新年的第一个需求.....

好吧,接客,开工!

思路:遍历文件夹--读word--解析--写excel

1.从shell命令方式开始。

平时使用比较多的就是git命令,经验不是不多。但是不就是读写文件么!

cat、more、less......卧槽,乱码!vim还是乱码!

网上冲浪一下吧!发现antiword命令,开始整!参考链接:antiword安装以及使用

发现了几个问题:

1.antiword只支持doc格式,而我的资源是docx的。

2.我的资源说是word,但内容是word中的table,也就是表格。antiword命令无法获取的指定模块的内容,也就是table的cell中的内容。


antiword命令展示的内容

2.放弃shell,使用Python

在搜索中发现了这个:Linux下读取doc,docx文件 使用Python来搞

Python也略懂一些,开整!一年前简单学习过一段时间,但好多东西都忘的差不多了,只能边整边搜

安装docx:sudo pip3 install docx 

进入Python开发模式测试:


python命令模式

报错 ModuleNotFoundError: No module named 'docx'

各种编程语言的思路都差不多,注意语法就行。但是这个三方库的安装,有点让我头疼。

后来参考链接:python安装docx模块出现Import Error: No module named 'exceptions'的解决方案

按照链接的操作了一下卸载docx: sudo uninstall docx

下载了python_docx-0.8.10-py2.py3-none-any.whl文件(这个文件很重要,后面最终的解决方式里用到了)

安装:sudo pip3 install python_docx-0.8.10-py2.py3-none-any.whl

还是报错ModuleNotFoundError: No module named 'docx'

使用PyCharm开发工具并且安装docx库

使用之前下载好的python_docx-0.8.10-py2.py3-none-any.whl文件

Pycharm->Preferences->Project:工程名->Project Interpreter->设置按钮->Show All...


点击设置按钮

选中当前工程,点击show paths for the selected interpreter按钮


点击show paths for the selected interpreter按钮

添加python_docx-0.8.10-py2.py3-none-any.whl文件


添加python_docx-0.8.10-py2.py3-none-any.whl

代码部分

代码部分我就直接贴图了,本人感觉对不熟悉的开发语言就是要自己动手打,拷贝粘贴对代码理解上不如自己敲......

好吧我承认是我自己懒

代码

简单解释一下

我在桌面上有一个文件夹,命名“1”,里面放的都是word文件,都是docx类型。还有一个excel文件:1.xlsx

结束语

第一次做分享,真的好难。以前都是看别人分享内容,感觉写的不好的心理都会骂上几句:神马玩意。当自己尝试后发现真的好难。不知道怎么表达自己的想法,还怕别人看不懂。

怎么说这也是一个好的开始,希望能帮组到有需要的人。

感谢做分享的人

感谢文中链接的作者

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容