需求:为一个文件夹下的所有EXCEL文件添加密码保护,并且在每个文件中添加一个Sheet页,在这个sheet业中展示公司的数据保密规定。
最终源码:
import os, sys
import win32com.client
def pwd_xlsx(old_filename,new_filename,pwd_str,pw_str=''):
xcl = win32com.client.Dispatch("Excel.Application")
wb = xcl.Workbooks.Open(old_filename, False, False, None, pw_str)
wb.Worksheets.Add().Name = u"数据保密规定"
sheets = wb.Worksheets(u"数据保密规定")
sheets.Move(wb.Worksheets(1), None)
a = sheets.Range("A1")
t = sheets.Range("I35")
pic = sheets.Shapes.AddPicture("D:\\excelInput\\bmxy.jpg",1,1,a.Left,a.Top,t.Left,t.Top)
xcl.DisplayAlerts = False
wb.SaveAs(new_filename, None, pwd_str, '')
xcl.Quit()
if __name__ == '__main__':
dirs = os.listdir("D:\\excelInput")
pwd_str = '123456'
print("start with password:" +pwd_str)
for file in dirs:
if file.split('.')[-1] != "jpg":
old_filename = 'D:\\excelInput\\' + file
new_filename = 'D:\\excelOutput\\' + file
pwd_xlsx(old_filename,new_filename,pwd_str)
print(file+"......100%")
print("finish....")
PS:都说pywin32是对VBA的一个封装,一些操作可以从windows的VBA文档里找找方法,比如上述代码中sheets.move方法和sheets.Shapes对象都是可以在EXCEL对象模型文档中找到的。附:windows VBA API