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
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Python中,可以使用win32com模块来操作Excel,通过该模块可以新建Excel文件并命名表格。 首先,需要安装pywin32库。可以使用以下命令进行安装: ```python pip install pywin32 ``` 然后,导入win32com.client模块以及相关的常量模块。如下所示: ```python import win32com.client as win32 from win32com.client import constants ``` 接下来,通过调用win32模块的Dispatch方法实例化Excel应用程序对象。 ```python excel = win32.gencache.EnsureDispatch('Excel.Application') ``` 然后,可以通过调用Application对象的Workbooks属性的Add方法来创建一个新的Excel工作簿,并保存为指定文件名: ```python workbook = excel.Workbooks.Add() workbook.SaveAs('文件路径/文件名.xlsx') ``` 接下来,可以获取工作簿中的第一个工作表,并通过调用Worksheet对象的Name属性来命名该工作表: ```python worksheet = workbook.Sheets(1) worksheet.Name = '工作表名字' ``` 最后,使用Application对象的Quit方法来关闭Excel应用程序。如下所示: ```python excel.Quit() ``` 完整的示例代码如下所示: ```python import win32com.client as win32 from win32com.client import constants excel = win32.gencache.EnsureDispatch('Excel.Application') workbook = excel.Workbooks.Add() workbook.SaveAs('文件路径/文件名.xlsx') worksheet = workbook.Sheets(1) worksheet.Name = '工作表名字' excel.Quit() ``` 以上就是使用win32com模块在Python中新建Excel并命名sheet的方法。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值