因为工作需要操作一些word文档,记录一下学习思路

#-*- encoding: utf8 -*-
import win32com
from win32com.client import Dispatch, constants
import win32com.client
import __main__
import os
import new
import sys
import re
import string
reload(sys)
sys.setdefaultencoding('utf8')
#from fileinput import filename

class Word(object):
    #初始化word对象
    def __init__(self, uri):
        self.objectword(uri)

    #创建word对象
    def objectword(self,url):
        self.word = win32com.client.Dispatch('Word.Application')
        self.word.Visible = 0
        self.word.DisplayAlerts = 0

        self.docx = self.word.Documents.Open(url)
        self.wrange = self.docx.Range(0, 0)

    #关闭word
    def close(self):
        self.word.Documents.Close()
        self.word.Quit()
    #创建word
    def create(self):

        pass
    #在word中进行查找
    def findword(self, key):
        question = []
        uri = r'E:\XE\ctb.docx'
        self.objectword(uri)
        #读取所有的word文档内容
        range = self.docx.Range(self.docx.Content.Start,self.docx.Content.End)
        question = str(range).split("&")
        #查找内容
        #question = re.split(r"(\r[1][0-9][0-9]+.)",str(range))
        #l = question[0].split("\d+.")
        for questionLine in question:
            questionLine = questionLine.strip('\n')
            l = re.split(r"([1][0-9][0-9]+.)",questionLine)
            del l[0]
            for t in l:
                s = str(key[0:3])
                if str(t).find(s) > -1:
                    #插入
                    g = string.join(l)

                    print g.encode('gb2312')
                    #print g.decode("")
                    self.insertword(g)
                    print "sss"
                else:
                    print "ttt"

    #插入word
    def insertword(self,w):
        url = r'E:\XE\ctb.doc'
        self.objectword(url)
        self.wrange.InsertAfter(w)
        pass

    #读取数据源
    def source(self, src):
        f = open(src)
        d = f.readlines()
        for l in d:
            name, question01, question02, question03, question04, question05 = tuple(l.decode('utf8').split('\t'))
            if question01 != u'全对':
                #self.wrange.InsertAfter(name)
                self.findword(question01)
        return self

Word(r'E:\XE\xx.docx').source(r'E:\XE\xe.txt').close()

  

python 操作word文档的更多相关文章

  1. 利用Python操作Word文档【图片】

    利用Python操作Word文档

  2. python操作docx文档(转)

    python操作docx文档 关于python操作docx格式文档,我用到了两个python包,一个便是python-docx包,另一个便是python-docx-template;,同时我也用到了很 ...

  3. Python之word文档替换字符串(也可以用于短模板套用)

    Python之word文档替换字符串(也可以用于短模板套用),代码如下: 1 ''' 2 #word模板套用1:创建模板,适合比较短的文档 3 ''' 4 5 #导入所需库 6 from docx i ...

  4. iText操作word文档总结

    操作word文档的工具有很多,除了iText之外还有POI,但是POI擅长的功能是操作excel,虽然也可以操作word,但是能力有限,而且还有很多的bug,技术并不成熟,下面就重点介绍一种操作wor ...

  5. C#操作Word文档(加密、解密、对应书签插入分页符)

    原文:C#操作Word文档(加密.解密.对应书签插入分页符) 最近做一个项目,客户要求对已经生成好的RTF文件中的内容进行分页显示,由于之前对这方面没有什么了解,后来在网上也找了相关的资料,并结合自己 ...

  6. Java文件操作系列[3]——使用jacob操作word文档

    Java对word文档的操作需要通过第三方组件实现,例如jacob.iText.POI和java2word等.jacob组件的功能最强大,可以操作word,Excel等格式的文件.该组件调用的的是操作 ...

  7. 使用Python操作Excel文档(一)

    Python | 使用Python操作Excel文档(一) 0 前言 在阅读本文之前,请确保您已满足或可能满足以下条件: 请确保您具备基本的Python编程能力. 请确保您会使用Excel. 请确保您 ...

  8. Python之word文档模板套用 - 真正的模板格式套用

    Python之word文档模板套用: 1 ''' 2 #word模板套用2:套用模板 3 ''' 4 5 #导入所需库 6 from docx import Document 7 ''' 8 #另存w ...

  9. Python读取word文档内容

    1,利用python读取纯文字的word文档,读取段落和段落里的文字. 先读取段落,代码如下: 1 ''' 2 #利用python读取word文档,先读取段落 3 ''' 4 #导入所需库 5 fro ...

随机推荐

  1. UTC+0800是什么意思

    <%@ language="javascript" %> <html> <body> <% var d=new Date() var h= ...

  2. HDU 2516 取石子游戏(FIB博弈)

    取石子游戏 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  3. #用Python直接写UTF-8文本文件

    当我们这样建立文件时 f = file('x1.txt', 'w') f.write(u'中文') f.colse() 直接结果应该是类似 f.write(u'中文') UnicodeEncodeEr ...

  4. labview中的文件格式

     

  5. Xcode环境配置mysql

    本文默认mysql安装目录为/usr/local/mysql 在项目的header search paths中添加/usr/local/mysql/includ 2.在项目的library searc ...

  6. java进程状态

    A thread state. A thread can be in one of the following states: NEWA thread that has not yet started ...

  7. easyui问题小记

    在easyui1.4.3版本中,(其他版本不知道是不是也是这样的),绑定在datagridview上面的数据最好不要是带有特殊符号的字段,不然会导致部分的属性不好用,比如这样的字段  START_DA ...

  8. JS、OnClientClick、OnClick

    OnClientClick是客户端事件处理方法,一般采用JavaScript来进行处理,也就是直接在浏览器端运行,一点击就运行: OnClick是服务器端事件处理方法,在服务器端也就是IIS中运行,点 ...

  9. ZOJ 3597 Hit the Target! (线段树扫描线 -- 矩形所能覆盖的最多的点数)

    ZOJ 3597 题意是说有n把枪,有m个靶子,每把枪只有一发子弹(也就是说一把枪最多只能打一个靶子), 告诉你第 i 把枪可以打到第j个靶, 现在等概率的出现一个连续的P把枪,在知道这P把枪之后,你 ...

  10. HDU 5437 Alisha’s Party (优先队列模拟)

    题意:邀请k个朋友,每个朋友带有礼物价值不一,m次开门,每次开门让一定人数p(如果门外人数少于p,全都进去)进来,当最后所有人都到了还会再开一次门,让还没进来的人进来,每次都是礼物价值高的人先进.最后 ...