Windows,Linux下读取Docx,Doc 文档

Windows

Doxc

下载python-docx模块库

pip install python-docx
import docx

word = "a.docx"
document = docx.Document(word)
for paragraph in document.paragraphs:
    text = paragraph.text
print(text)

Doc

下载win32com模块库,只支持Windows下

python -m pip install pypiwin32
from win32com import client
import pythoncom

word = "a.docx"
pythoncom.CoInitialize()
word = client.Dispatch('Word.Application')
word.Visible = 0  # 后台运行,不显示
word.DisplayAlerts = 0  # 不警告
doc = word.Documents.Open(word)
for para in doc.paragraphs:
    print(para.Range.Text)
doc.SaveAs('D:PythonFiles/4paradigm/gdt_flask/file/test.txt', 2)
doc.Close()
word.Quit()
pythoncom.CoUninitialize()

Linux

Doxc

下载python-docx模块库

pip install python-docx
import docx

word = "a.docx"
document = docx.Document(word)
for paragraph in document.paragraphs:
    text = paragraph.text
print(text)

Doc

安装 antiword
下载地址:http://www.winfield.demon.nl/linux/antiword-0.37.tar.gz

解压进入目录
tar -zxvf antiword-0.37.tar.gz

cd  antiword-0.37

make && make install

安装时,自动安装到了/root/目录下,只有root才可执行该命令,我们需要改一下路径,COPY到/usr中方便调用。

cp /root/bin/*antiword /usr/local/bin/
mkdir /usr/share/antiword
cp -R /root/.antiword/* /usr/share/antiword/
chmod 777 /usr/local/bin/*antiword
chmod 755 /usr/share/antiword/*
"""
    代码用法
"""
word = "a.doc"
output = subprocess.check_output(["antiword", word])
# 解码
output = output.decode('utf8')
print(output)

Fighter_ma: 弱小和无知不是生存的障碍,傲慢才是~

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值