zoukankan      html  css  js  c++  java
  • Python2 获取docx/doc文件内容

    整体思路:

     下载文件并修改后缀为zip文件,解压zip文件,所要获取的内容在固定的文件夹下:work/temp/word/document.xml

    所用包,全部是python自带,不需要额外下载安装. 

    # encoding:utf-8
    import os
    import re
    import requests
    import zipfile
    import xml.dom.minidom

    newfile = 'test.docx'


    def create(newfile):
    """下载docx文件,并修改后缀为zip"""
    res = requests.get('https://www.cqjbfy.gov.cn/publiccenter/splc/mb/splc_gginfo.asp?newsid=28949')

    if not os.path.exists(newfile):
    f = open(newfile, 'wb')
    for chunk in res.iter_content(100000):
    f.write(chunk)
    f.close()

    os.rename(newfile, 'test.zip') 这种方法发现只能解决一部分doc文件,具体原因不得而知,有明白的欢迎留言
        # 将doc/docx文件压缩成zip文件
        #pf = zipfile.ZipFile('test.zip', 'w', zipfile.ZIP_STORED) 
    #pf.write(newfile)

    def get_txt():
    """解压zip,并在work/temp/word/document.xml获取文本内容,进行正则替换标签等操作"""
    f = zipfile.ZipFile('test.zip', 'r')
    for file in f.namelist():
    f.extract(file, "temp/")

    f = xml.dom.minidom.parse('./temp/word/document.xml')

    txt = re.sub(r'</w:t></w:r></w:p>', ' ', f.toxml())
    print re.sub(r'<.*?>', '', txt)

    if __name__ == '__main__':
    create(newfile)
    get_txt()
    pasting
  • 相关阅读:
    Redux 学习总结
    ECMAScript 6 学习总结
    Bootstrap 前端UI框架
    React.js 学习总结
    html 之 <meta> 标签之http-equiv
    Leetcode Excel Sheet Column Number (C++) && Excel Sheet Column Title ( Python)
    490
    414
    494
    458
  • 原文地址:https://www.cnblogs.com/fanjp666888/p/9877968.html
Copyright © 2011-2022 走看看