python的dispatch_win32com.client.Dispatch()函数用法

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

这里有个Word的,,,供你参考:

要使用Python控制MS Word,您需要先安裝win32com套件,這個套件可以到 http://sourceforge.net/projects/pywin32/找到。本文假設您已經正確安裝win32com及相關套件,所以將不再針對此部分多做說明。

毫無疑問的,您需要先import win32com模組才能進行Word的控制。

import win32comfrom win32com.client import Dispatch, constants

接著,要讓我們的Python程式和MS Word建立起連結。

msword = Dispatch('Word.Application')

用Dispatch()的方式將會啟動MS Word。不過,如果您已經有執行MS Word,則此方式只會與現存的MS Word建立連結。如果您強烈希望能夠有一個新的MS Word程式出現,可用下面的方式:

msword = DispatchEx('Word.Application')

此時您會發現畫面上沒有任何MS Word出現,其實他已經在背後執行了。您可以透過工作管理員來查看是否有一個名為"WINWORD.EXE"的Process。不產生畫面的好處是您可 以在背景來處理您要進行的工作。如果您想要看看到底是不是真的有成功的啟動MS Word,請設定Visible屬性。

msword.Visible = 1 # 1表示要顯示畫面,若為0則不顯示畫面。您可以隨時的更改此屬性。

除了不顯示畫面外,您也許還會希望不要顯示一些警告訊息。此時請設定DisplayAlerts屬性:

msword.DisplayAlerts = 0 # 1表示要顯示訊息,0則會隱藏訊息。

若您真的有把畫面叫出來,您或許會發現此時的畫面上是沒有任何文件開啟的。沒錯!前面的動作只是幫助我們啟動Word並且建立連結,接著我們就要來開啟文件了。我們可以開啟已經存在的文件,或者是新增一個空白文件。

doc = msword.Documents.Open(FileName="xxx.doc") # 開啟一個名為xxx.doc的文件。newDoc = msword.Documents.Add() # 開啟一個新的文件。msword.Quit() # 關閉MS Word.

當然,除了開啟檔案或新建文件,您也可以存檔或者控制這些文件。

docCnt = msword.Documents.Count # 取得目前開啟文件的數量。doc = msword.Documents[n] # 取得第n個文件的物件,以便後面的控制。doc.Activate() # 將文件設定為主要工作文件。doc.PrintOut() # 列印文件doc.Save() # 存檔doc.SaveAs('xxx.doc') # 另存新檔doc.Undo(n) # 回復前n次的動作

取得與文件的聯繫,接著我們可以對他進行編輯。不過,我們要能夠先取得編輯的控制權。透過Document的Range()函式,我們可以取得MS Word的Range物件。

range = doc.Range(0, 0) # 取得Range物件,範圍為文件的最開頭。range = doc.Range() # 取得Range物件,範圍為文件的最尾端。range = doc.Range(doc.Content.Start, doc.Content.End) # 取得Range物件,範圍整份文件。

有了Range物件,我們就可以開始進行編輯了。

range.InsertBefore('在range前面插入的文字')range.InsertAfter('在range後面插入的文字')select = range.Select() # 將range的範圍全部選取。並且取得Selection物件。

如果要設定Style,可以透過range物件的Style屬性來設定。

range.Style = constants.wdStyleHeading1 # 設定style為Heading 1range.Style = constants.wdStyleHeading2 # 設定style為Heading 2range.Style = constants.wdStyleHeading3 # 設定style為Heading 3range.Style = constants.wdStyleHeading4 # 設定style為Heading 4range.Style = constants.wdStyleHeading5 # 設定style為Heading 5range.Style = constants.wdStyleHeading6 # 設定style為Heading 6range.Style = constants.wdStyleHeading7 # 設定style為Heading 7range.Style = constants.wdStyleHeading8 # 設定style為Heading 8range.Style = constants.wdStyleHeading9 # 設定style為Heading 9range.ParagraphFormat.Alignment = constants.wdAlignParagraphLeft # 設定段落為靠左range.ParagraphFormat.Alignment = constants.wdAlignParagraphRight # 設定段落為靠右range.ParagraphFormat.Alignment = constants.wdAlignParagraphCenter # 設定段落為置中range.ParagraphFormat.Alignment = constants.wdAlignParagraphJustify # 設定段落為左右對齊range.Style.Font.Name = "Arial" # 設定字型為Arialrange.Style.Font.Name = "Time New Roman" # 設定字型為Time New Romanrange.Style.Font.Name = "標楷體" # 設定字型為標楷體range.Style.Font.Color = 0xFF0000 # 設定字型的顏色為Bluerange.Style.Font.Color = 0x00FF00 # 設定字型的顏色為Greenrange.Style.Font.Color = 0x0000FF # 設定字型的顏色為Redrange.Style.Font.Bold = 1 # 設定字型為粗體字range.Style.Font.Italic = 1 # 設定字型為斜體字range.Style.Font.Underline = 1 # 為字型加底線range.Style.Font.Shadow = 1 # 為字型加陰影range.Style.Font.Outline = 1 # 為字型加外框

如果要插入一個表格,可以用下面的方式來做。

table = doc.Tables.Add(range, 3, 4) # 新增一個3x4表格table.Cell(1,1).Range.InsertAfter('Some text') # 新增文字到cell(1,1)table.Cell(1,1).Range.Font.Name = "Arial" # 設定字型為Arialtable.Cell(1,1).Range.Font.Color = 0xFF0000 # 設定字型為bluetable.Rows.Add() # 新增一個Rowtable.Columns.Add() # 新增一個Column 摘自:http://www.360doc.com/content/14/0727/17/18692661_397450872.shtml

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
win32com.client.DispatchPython中的一个函数,它用于创建和连接到COM服务器对象。COMComponent Object Model)是一种微软开发的组件对象模型,是一种用于实现软件组件互操作的技术。通过COM,可以在不同的程序之间共享对象,并且这些对象可以在不同的语言中编写。 在Python中,使用win32com.client.Dispatch函数可以连接到COM服务器并创建COM对象。该函数的语法如下: ```python win32com.client.Dispatch(prog_id=None, clsid=None, machine=None, userName=None, password=None, typeinfo=None) ``` 其中,参数prog_id指定要创建的COM对象的程序标识符(Program ID),clsid指定要创建的COM对象的类标识符(Class ID),machine指定COM服务器所在的计算机名,userName和password指定连接到COM服务器的用户名和密码,typeinfo指定类型信息(Type Information)。 例如,下面的代码创建一个Excel应用程序对象: ```python import win32com.client excel = win32com.client.Dispatch('Excel.Application') ``` 这段代码中,'Excel.Application'是Excel应用程序的ProgID,通过调用win32com.client.Dispatch函数并传入该ProgID,可以创建一个Excel应用程序对象。然后,可以使用该对象来操作Excel应用程序,比如打开一个工作簿、读写单元格等。 总之,win32com.client.Dispatch函数Python中连接到COM服务器并创建COM对象的重要函数,它为Python程序员提供了方便的方式来操作COM服务器上的对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值