streethacker 发表于 2014-05-19 17:24

python如何进行位运算?

本帖最后由 streethacker 于 2014-05-19 17:23 编辑

问题背景:
    我现在需要用Pyhon实现一个LBlock加密算法,加密的流程是一个类Feistel网络,具体的加密流程如下:
   
   
   
   

问题:
    算法中不论是从文件还是从终端输入的明文都是字符串形式的,但算法中需要对明文按照比特位进行分组,且需要进行循环移位、异或等位运算。
    字符串不能直接支持这样的位运算,请问怎样才能对字符串做一些转换,使得这些运算可以执行?
    或者有没有其他方法,可以实现算法中的分组、移位、异或等运算?

要求:
    不论是对明文字符串或者密钥字符串进行转换,还是其他的方法,都不能影响到加密的结果。

yjphhw 发表于 2014-05-20 11:43

不太懂你说的,但是要做位运算是很容易的。
>>> 4>>2
1
>>> 4>>1
2
>>> 4<<2
16
>>> 3|4
7
>>> 3&4
0
>>>

还有就是你说的自符串变换
不太理解
如果自符串本身是数据
那你直接 int('34324')就好

如果是其它的比如用16进制,什么你可以考虑base64模块里,转换
然后,再用struct 模块转成数字然后就可以操作。

页: [1]
查看完整版本: python如何进行位运算?