Python_13-Office文件数据操作
目录:
1.1 安装win32com模块
1.2 Access数据库操作
1.2.1 建立db1.db数据库,设计一张表t_student_b
1.3 Excel文件操作
1.3.1 读取Excel
1.4 Word文件操作
1.4.1 示例1:打开,另存为
1.4.2 示例2:更多功能
1.1 安装win32com模块
下载地址:
http://sourceforge.net/projects/pywin32/
1.2 Access数据库操作
1.2.1 建立db1.db数据库,设计一张表t_student_b
示例
#Python操作Access数据库步骤之1、建立数据库连接
import win32com.client
conn = win32com.client.Dispatch(r'ADODB.Connection')
print '111'
DSN = 'PROVIDER=Microsoft.Jet.OLEDB.4.0;DATA SOURCE=d:\\python279\\db1.mdb;'
conn.Open(DSN)
print '222'
#Python操作Access数据库步骤之2、打开一个记录集
rs = win32com.client.Dispatch(r'ADODB.Recordset')
rs_name = 't_student_b'#表名
rs.Open('[' + rs_name + ']', conn, 1, 3)
#Python操作Access数据库步骤之3、对记录集操作
rs.AddNew()
rs.Fields.Item(1).Value = '102'
rs.Fields.Item(2).Value = 'Li Yong'
rs.Update()
sql_statement = "insert into t_student_b (studno, studname) values ('201101', 'LiLee')"
#sql_statement = 'select * from t_student_b order by studno';
print '333'
conn.Execute(sql_statement)
print '444'
conn.Close()
1.3 Excel文件操作
1.3.1 读取Excel
编写操作类
from win32com.client import constants, Dispatch
class EasyExcel:
def __init__(self, filename=None):
self.xlApp = Dispatch('Excel.Application')
if filename:
self.filename = filename
self.xlBook = self.xlApp.Workbooks.Open(filename)
else:
print "please input the filename"
def close(self):
self.xlBook.Close(SaveChanges=0)
del self.xlApp
def getCell(self, sheet, row, col):
"Get value of one cell"
sht = self.xlBook.Worksheets(sheet)
return sht.Cells(row, col).Value
def getRange(self, sheet, row1, col1, row2, col2):
"return a 2d array (i.e. tuple of tuples)"
sht = self.xlApp.Worksheets(sheet)
return sht.Range(sht.Cells(row1, col1), sht.Cells(row2, col2)).Value
示例:
#from easyExcel import EasyExcel
#from texcel import EasyExcel
excelProxy = EasyExcel("d:\\python279\\test.xls")
content=excelProxy.getRange("sheet1",1,1,2,2)
print content
1.4 Word文件操作
要使用Python控制MS Word,您需要先安装win32com套件,这个套件可以到 http://sourceforge.net/projects/pywin32/ 找到。您需要先import win32com模块才能进行Word的控制。
1.4.1 示例1:打开,另存为
from win32com.client import Dispatch, constants
from win32com.client.gencache import EnsureDispatch
EnsureDispatch('Word.Application') #makepy 导入Word类库,否则constants无法使用
msword = Dispatch('Word.Application')
msword.Visible = True #是否可见
msword.DisplayAlerts = 0
strDir='d:\\python279\\';
doc = msword.Documents.Open(FileName = strDir + r'test.doc') #打开已有文件
newdoc = msword.Documents.Add() #添加新文件
newdoc.SaveAs('new.doc') #另存为
1.4.2 示例2:更多功能
#Python 操作Word(Excel、PPT等通用)
import win32com
from win32com.client import Dispatch, constants
w = win32com.client.Dispatch('Word.Application')
# 或者使用下面的方法,使用启动独立的进程:
# w = win32com.client.DispatchEx('Word.Application')
# 后台运行,不显示,不警告
w.Visible = 1
w.DisplayAlerts = 0
filenamein = 'test.doc'
# 打开新的文件
#doc = w.Documents.Open( FileName = filenamein )
worddoc = w.Documents.Add() # 创建新的文档
# 插入文字
#myRange = doc.Range(0,0)
myRange = worddoc.Range(0,0)
myRange.InsertAfter('Hello from Python! 111\n')
w.Selection.TypeParagraph; #换行
myRange.InsertAfter('Hello from Python! 222\n')
#wordSel = myRange.Select()
myRange = worddoc.Range(0,0)
w.Selection.Style = constants.wdStyleHeading1 #找不到Style
# 正文文字替换
OldStr = 'Hello'
NewStr = 'How are you'
#w.Selection.Find.ClearFormatting()
#w.Selection.Find.Replacement.ClearFormatting()
#w.Selection.Find.Execute(OldStr, False, False, False, False, False, True, 1, True, NewStr, 2)
# 页眉文字替换
print('page header:')
#w.ActiveDocument.Sections[0].Headers[0].Range.Find.ClearFormatting()
#w.ActiveDocument.Sections[0].Headers[0].Range.Find.Replacement.ClearFormatting()
#w.ActiveDocument.Sections[0].Headers[0].Range.Find.Execute(OldStr, False, False, False, False, False, True, 1, False, NewStr, 2)
# 表格操作
print('table:')
#myRange = worddoc.Range(0,0)
#worddoc.Tables.Add(myRange, 5, 4)
w.Selection.TypeParagraph; #换行
#w.Selection.TypeText = 'test';
#w.Content.InsertAfter.Text = 'test'
#w.Selection.TypeParagraph;
myRange = worddoc.Range(worddoc.Sentences.Last.End -1,worddoc.Sentences.Last.End -1)
#w.Selection.Style = '正文'
w.Selection.ClearFormatting()
myRange.InsertAfter('Hello from Python! 333\n')
myRange.InsertAfter('Hello from Python! 444\n')
myRange.InsertAfter('Hello from Python! 555\n')
myRange.InsertAfter('Hello from Python! 333\n')
myRange = worddoc.Range(worddoc.Sentences.Last.End -1,worddoc.Sentences.Last.End -1)
w.ActiveDocument.Tables.Add(myRange, 2, 5)
#w.ActiveDocument.Tables.Add(wmyRange, 2, 5)
'''
if w.Selection.Tables(1).Style <> "网格型":
w.Selection.Tables(1).Style = "网格型"
w.Selection.Tables(1).ApplyStyleHeadingRows = True
w.Selection.Tables(1).ApplyStyleLastRow = True
w.Selection.Tables(1).ApplyStyleFirstColumn = True
w.Selection.Tables(1).ApplyStyleLastColumn = True
'''
#w.Selection.
#worddoc.Tables[0].Rows[0].Cells[0].Range.Text ='123123'
#worddoc.Tables[0].Rows.Add() # 增加一行
# 转换为html
print('html:')
filenameout = 'd:\\python279\\mytest.html';
wc = win32com.client.constants
w.ActiveDocument.WebOptions.RelyOnCSS = 1
w.ActiveDocument.WebOptions.OptimizeForBrowser = 1
w.ActiveDocument.WebOptions.BrowserLevel = 0 # constants.wdBrowserLevelV4
w.ActiveDocument.WebOptions.OrganizeInFolder = 0
w.ActiveDocument.WebOptions.UseLongFileNames = 1
w.ActiveDocument.WebOptions.RelyOnVML = 0
w.ActiveDocument.WebOptions.AllowPNG = 1
#w.ActiveDocument.SaveAs( FileName = filenameout, FileFormat = wc.wdFormatHTML ) # right work
# 打印
#doc.PrintOut()
#worddoc.PrintOut()
# 关闭
#doc.Close()
#worddoc.Close()
#w.Documents.Close(wc.wdDoNotSaveChanges)
#w.Quit()
其他例子:
相关文章
- 【EXCEL】详解使用python读写EXCEL文件(xlrd,xlwt)
- python按txt文件读取图像,复制并改名
- python按行分割文件:python 划分数据集文件(txt标签文件按比例随机切分)
- PYTHON对文件及文件夹的一些操作
- 文件操作mode学习总结-----Python学习总结【第四篇】:Python之文件操作(文件、正则、json、pickle)
- python文件读写操作与linux shell变量命令交互执行
- Python学习入门基础教程(learning Python)--5.7 Python文件数据记录存储与处理
- python里面出现中文的时候报错 'ascii' codec can't encode characters in position
- 在mac上 使用jenkins 执行python文件
- windows 64位 dll文件 位置及python包rtree shapely安装
- Python库【数据处理、机器学习、大数据、文件处理等14个类的所有python库整理】
- Python xlwt数据保存到 Excel中以及xlrd读取excel文件画图
- 【问题记录与解决】启动Jupyter,运行代码时报错【Error】 || 通过 Jupyter 建立的Python文件在哪儿 || Jupyter 中 移动 Python 文件 到 指定文件夹
- Gerber file Gerber文件解析 .gbx光绘文件读取绘制 C++ Python OpenCV
- python pip 快速安装第三方库和下载好whl文件
- python 引用(import)文件夹下的py文件
- 流畅的python第二十章属性描述符学习记录
- python练习19 -- 协程
- PyQt(Python+Qt)学习随笔:windows下使用pyinstaller将PyQt文件打包成exe可执行文件
- 第11.4节 Python正则表达式搜索字符集匹配功能及元字符”[]”介绍
- 第9章 Python文件操作目录
- python scikit-learn计算tf-idf词语权重
- Python OS 文件/目录方法
- 已解决TypeError: only size-1 arrays can be converted to Python scalars
- Python 读写文件通用工具函数方法
- python下载文件只要一句话
- 用Python赚钱的5个方法,教你业余时间赚外快!
- 想学Python爬虫,数据分析,自动化办公,没有任何编程基础,该如何入门?
- 2022年最新Python大数据之Python基础【八】文件的操作与类
- python和c#通用一致的des加密采用CBC和PKCS7
- python - 输入目录,输出打印全部文件及文件夹
- python close()方法清空文件内容
- 【Python 入门】文件IO
- [ Python入门教程 ] Python文件基本操作_os模块
- HackTheBox Vessel Git文件代码审计,Node.js登录身份验证绕过,CVE-2022-24637利用,python反编译和CVE-2022-0811提权
- Python 开发 漏洞的批量搜索与利用.(GlassFish 任意文件读取)