用python写一个专属字典生成器
在我們滲透學(xué)習(xí)的過程中,時常需要字典來對后臺密碼和用戶名進(jìn)行爆破攻擊,但是現(xiàn)有的字典又過于龐大高達(dá)10G,跑完字典十分浪費時間,所以我決定基于python構(gòu)思一個字典生成器
如1 2 3 可以組合成 123 213 231 321 312 132;
首先我們需要輸入數(shù)據(jù)
a=input("請輸入要生成的數(shù)據(jù)") b=list(a.split(" "))我們輸入的數(shù)據(jù)通過列表的方式進(jìn)行保存
但是如果數(shù)據(jù)輸入錯誤該怎么辦
于是我在代碼中加入一個判斷語句
a=input("請輸入要生成的數(shù)據(jù)") b=list(a.split(" ")) print(b) print("請檢查輸入數(shù)據(jù)是否正確") c=input("y/n: ") while(c!="y"):input0()input1()b=""當(dāng)然最重要的是對輸入的數(shù)據(jù)進(jìn)行排序
一般來說是通過設(shè)計算法來進(jìn)行組合。
但是我們用的語言是PYTHON 怎么能像C語言一樣重復(fù)造輪子呢
于是一個強大的標(biāo)準(zhǔn)庫來啦
python自帶的標(biāo)準(zhǔn)庫itertools可以幫助我們對數(shù)據(jù)進(jìn)行組合
具體的使用方法如下
python itertools 使用詳解_尋尋覓覓oO的博客-CSDN博客_itertools
可以參考一下
x = its.permutations(b, co) ls1=list(x)但是我們生成字典需要保存啊
引用 os 來寫入數(shù)據(jù)
這樣我們的字典生成器完成了8成;
通過這幾步生成的數(shù)據(jù) ennnn
?看著頭都大了 這字典不保熟啊,用不了啊
于是要對數(shù)據(jù)進(jìn)行處理變成我們可以使用的數(shù)據(jù)
for ch in "[' ) ( ,]" :txt=txt.replace(ch,"") s=-1 for i in txt:s=s+1if s%co==0:zd.write("\n")zd.write(i) zd.close()通過處理我們可以得到一個完美的字典
?
這樣暴庫是不是更快了hhhhhhh
完整代碼如下
import os import itertools as its print("歡迎來到字典生成器") print("---------------------") def input0():a=input("請輸入要生成的數(shù)據(jù)")b=list(a.split(" "))print(b)print("請檢查輸入數(shù)據(jù)是否正確") def input1():c=input("y/n: ") a=input("請輸入要生成的數(shù)據(jù)") b=list(a.split(" ")) print(b) print("請檢查輸入數(shù)據(jù)是否正確") c=input("y/n: ") while(c!="y"):input0()input1()b="" zd=open("1.txt","a") co=len(b) zd.write(str(b)) x = its.permutations(b, co) ls1=list(x) print("生產(chǎn)的密碼個數(shù):",len(ls1)) zd.write(str(ls1)) print("成功寫入") zd=open("2.txt","a") txt=open("1.txt","r").read() for ch in "[' ) ( ,]" :txt=txt.replace(ch,"") s=-1 for i in txt:s=s+1if s%co==0:zd.write("\n")zd.write(i) zd.close() print("成功處理")?
總結(jié)
以上是生活随笔為你收集整理的用python写一个专属字典生成器的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 目标检测数据集分享
- 下一篇: websocket python爬虫_p