[Python] python 破解Excel密码(还原工作表密码)

Excel 工作表编辑密码位数为12位 范围是AAAAAAAAAAA (注意A后面有个空格)至BBBBBBBBBBB~ 拥有194560个组合

支持xlsx,支持wps

原理:
在保护工作表或者工作簿时,如果你设置了密码(图2),那么无论该密码的长度是多少,Excel都会将其转换成包含12个字符的特殊序列,并将这个经过转换的密码保存在Excel中。因此,虽然很难猜测出原始密码,但我们可以分析这12个字符序列。
假如Excel将所设置的密码转换后与包含12个字符的序列匹配,那么就相当于获取了原来由密码所限制的权限,实际上就是破解了设置的密码。也就是说,你设置的密码是什么都没有关系,存储在Excel中的实际上就是这12个字符序列组合之一。由于这12个字符可以组合成大约200000个(95*2^11=194560)不同的序列,可以通过遍历这些序列来破解密码,实际上是解除Excel给用户设置的限制。

01

02

03

04

05

06

07

08

09

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

import win32com.client

a=[]

b=[]

c=[]

ProtectPass=[]

for in range(2048):

    a.append(list('{:011b}'.format(i))) #生成2^11次的组合列表,因为11位密码有2^11种排列组合方式,将排列组合列表作为成员添加到列表中,此时生成的是二进制0和1

#print(a)

for in a: # 遍历列表中的所有组合

    for in i: # 对排列组合列表中的各个成员值进行遍历

        b.append(int(j)+65# 对各个成员进行加65操作 0加65等于本身 1加65=66

    c.append(b) # 生成包含65和66的所有排列可能

    b=[]

for in c: # 对所有的排列可能进行遍历 得到每组排列组合的列表形式

    #print(k)

    m=list(k) # 转换成列表

    m.append(0#末尾再加一组成员0,因为要对其进行复制,末尾成员的值范围不是65或者66

    for in range(32,127):

        m[len(m)-1]=#末尾成员的赋值,范围是32-126

        #print(m)

        list2=[chr(i) for in m] #将int类型转化成ascii码,也就是字符

        str=''.join(list2) #将字符列表转成字符串

        ProtectPass.append(str# 最后将每一串字符串作为列表成员放入列表 方便破解密码

xlsx=win32com.client.Dispatch('Excel.Application'# 获得Excel对象

wb=xlsx.Workbooks.Open(r'C:\Users\Administrator\Desktop\hello.xlsx',False,False,None,Password="") #这里的Password是Excel文件打开密码 也可以使用穷举

xlsx.Visible = True #是否可见Excel界面

ws=wb.Sheets[1]  #获取第二张工作表,因为我设置了第二张工作表里面 第一张表则填0

# 如果是需要跑活动工作表的密码 可以使用 wb.ActiveSheet

for EditPass in ProtectPass:

    try:

        ws.Unprotect(EditPass)

        print(f"成功了 密码是{EditPass}"# 成功以后则直接跳出

        break

    except# 出现异常就代表密码错误  此时需要无视异常继续试下一个密码

        continue

参与人数 1热心值 +1收起理由
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大飞哥软件自习室

希望支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值