解决Excel保存时自动跳出来的Sensitivity Label选项问题(python自动化办公)

问题描述:企业内创建excel进行后续操作之后保存的时候,会跳出来显示sensitivity label的选项,此时必须手动去选择下拉列表的选项

解决办法:
1.首先依据现有的企业内部的excel得到不同的LabelId:

import xlwings as xw
wb=xw.Book("选择的excel路径名字")
labelId=wb.api.SensitivityLabel.getLabel().LabelId
	

2.依据上述不同的LabelId创建一个枚举类进行封装con_data.py:

import enum
class SensiLabel(enum.Enum):
#此处显示的时上述得到的ID值
	Public='a'
	Internal='b'
	Confidential='c'
	Restricted='d'

3.编写新建excel的代码块

from con_data import SensiLabel
import xlwings as xw
import os

class SenExcel():
    def __init__(self):
        
        self.absPath = r"文件夹路径"
        self.relativePath=os.getcwd()
        self.absFile=__file__
        
        

    def new_excel(self,fileName):
        self.newExcel = os.path.join(self.absPath, fileName)
        print(self.relativePath)
        print(self.absFile)
        return self.newExcel
        
    def handle_sen(self):
        
        self.newExcel=SenExcel.new_excel(self, fileName='test3.xlsx')
        
        
        app = xw.App(visible=True,add_book=False)  # 创建一个不可见的Excel应用程序实例,不添加新的工作簿
        workbook = app.books.add()
        labelinfo =workbook.api.SensitivityLabel.CreateLabelInfo()
        labelinfo.AssignmentMethod = 2
        labelinfo.Justification = 'init'
        labelinfo.LabelId = SensiLabel.Confidential.value
        workbook.api.SensitivityLabel.SetLabel(labelinfo, labelinfo)
        wb=workbook.save(self.newExcel) 
        workbook.close()
        app.quit()
        
if __name__ == '__main__':
    Data = SenExcel()
    Data.handle_sen()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值