python win32com 批量加密excel 新增sheet 调整sheet顺序

需求:为一个文件夹下的所有EXCEL文件添加密码保护,并且在每个文件中添加一个Sheet页,在这个sheet业中展示公司的数据保密规定。

最终源码:

# coding=utf-8

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"数据保密规定" #为文件添加一个名为数据保密规定的sheet页
    sheets = wb.Worksheets(u"数据保密规定")
    sheets.Move(wb.Worksheets(1), None) #把前两步添加的sheet页的顺序调成第一
    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) # 在添加的sheet页中插入一个图片用来展示数据保密规定
    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

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值