【python】将01组成的密码用ASCII编码成字符串

题目来自 hacker.org 的 Challenge 'Didactic Bytes' [Crypto]

给出一个01串组成的密码,求出破译后的单词

01110101 01110011 01100101 00100000 01110111 01100101 01100100 01101110 01100101 01110011 01100100 01100001 01111001 00100000 01100110 01101111 01110010 00100000 01110100 01101000 01100101 00100000 01100001 01101110 01110011 01110111 01100101 01110010

观察发现每个01串都是由0开头的8位二进制数,因此转化成十进制范围在127以内,由此联想到ASCII码。

---

s = "01110101 01110011 01100101 00100000 01110111 01100101 01100100 01101110 01100101 01110011 01100100 01100001 01111001 00100000 01100110 01101111 01110010 00100000 01110100 01101000 01100101 00100000 01100001 01101110 01110011 01110111 01100101 01110010"
bit = s.split()
dec = map(lambda x:int(x,2),bit)
print ''.join(map(chr,dec))

---

将密码以字符串的形式存入变量s中

str.split() 将字符串以空格为分隔符分离,结果以列表的形式保存到 bit 列表中。

用 map 对 bit 列表中的每个字符串执行 int(x, 2) ,将一串二进制数转化为十进制,将结果列表保存到 dec 中。

用chr() 将dec列表中的十进制数转化为字符,用 str.join(iterable) 将字符列表转化为字符串并输出。

原文地址:https://www.cnblogs.com/cyendra/p/3681511.html