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
    评论
Linux下提取文档内部文档的库可以使用LibreOffice来实现。LibreOffice是一款免费的开源办公软件套件,它包含了Writer、Calc、Impress等多个组件,其中Writer就是一个文档处理器,支持多种文档格式,如ODT、DOCDOCX、PDF等。 在Linux下,通过安装LibreOffice,可以使用其Python API来提取文档内部文档。具体步骤如下: 1. 安装LibreOffice。 ``` sudo apt-get install libreoffice ``` 2. 安装PyUno。 ``` sudo apt-get install python-uno ``` 3. 编写Python脚本,使用PyUno来提取文档内部文档。 ```python import uno import os def get_docx_content(docx_file): # 连接LibreOffice服务 local_context = uno.getComponentContext() resolver = local_context.ServiceManager.createInstanceWithContext("com.sun.star.bridge.UnoUrlResolver", local_context) context = resolver.resolve("uno:socket,host=localhost,port=2002;urp;StarOffice.ComponentContext") desktop = context.ServiceManager.createInstanceWithContext("com.sun.star.frame.Desktop", context) # 打开文档 url = uno.systemPathToFileUrl(os.path.abspath(docx_file)) doc = desktop.loadComponentFromURL(url, "_blank", 0, ()) # 提取文档内容 content = "" if doc: text = doc.getText() content = text.getString() # 关闭文档 doc.close(True) return content if __name__ == "__main__": docx_file = "test.docx" content = get_docx_content(docx_file) print(content) ``` 该脚本可以读取名为test.docx文档,并输出文档的内容。同时,也可以通过修改代码来读取其他格式的文档,如PDF等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值