不明白为什么会发生此“ OverflowError:Python int太大而无法转换为C long”的异常

时间:2019-02-21 22:08:59

标签: python bitstring

此代码接受一个位串并将其转换为字符串。该位串来自读取到客户端的txt文件,然后转换为位串然后发送到服务器。

def getChar(charstr):
    char = []
    for byte in charstr.split(): 
        char.append(chr(int(''.join([str(bit) for bit in byte]), 2)))
    return ''.join(char)

有问题的位串是:

10010011101101111000011001011100001110001111010001101101110010111011101110100100000110010110000110010110000100001

该行叫出

char.append(chr(int(''.join([str(bit) for bit in byte]), 2)))

并显示错误:

OverflowError: Python int too large to convert to C long.

我该如何解决?

完整服务器代码:

import socket
import random
import sys

def getCaesar(message, key):
    enc = ""
    for char in message: 
        if char == ' ':
            enc = enc + char
        elif  char.isupper():
            enc = enc + chr((ord(char)+key-65)%26+65)
        elif char.islower():
            enc = enc + chr((ord(char) + key - 97) % 26 + 97)
        else:
            enc = enc +chr((ord(char) + key - 33) % 32 + 33)

    return enc

def getBinary(bitstr):
    bit=' '.join(format(ord(char), 'b') for char in bitstr)
    return bit

def getChar(charstr):
    char = []
    for byte in charstr.split(): 
        char.append(chr(int(''.join([str(bit) for bit in byte]), 2)))
    return ''.join(char)

def getBitstr(k):
    result=""
    for num in range(0,k):
        result=''.join(str(random.randint(0,1))for num in range(k))
    return result

def getXor(a,b):
    a=a.replace(" ","")
    b=b.replace(" ","")
    result = int(a,2) ^ int(b,2)
    return '{0:b}'.format(result)

def Decrypt(message, key):
    enc = ""
    for char in message: 
        if char == ' ':
            enc = enc + char
        elif  char.isupper():
            enc = enc + chr((ord(char)-key-65)%26+65)
        elif char.islower():
            enc = enc + chr((ord(char) - key - 97) % 26 + 97)
        else:
            enc = enc +chr((ord(char) - key - 33) % 32 + 33)

    return enc

s=socket.socket(socket.AF_INET, socket.SOCK_STREAM)
host=socket.gethostname()
port=4000
s.bind((host,port))
s.listen(5)
print("Listening...")
while True:
    c,addr=s.accept()
    print("Got connection from ",addr)
    print("Receiving...")
    l = c.recv(4096).decode()

    a=str(l)
    cipherF=open("ciphertext.txt",mode='r')
    caesar=cipherF.read()
    key=Decrypt(caesar,4)
    key=''.join(key)
    b=str(key)

    content=getXor(a,b)

    dec=getChar(content)

    if not l:
        break
    print("Decrypting...")
    print(dec)

s.close()

1 个答案:

答案 0 :(得分:0)

chr函数将整数转换为关联的字符。 python版本之间的行为不同,如下所示:

在python 2.x中,如果chr(n)n将返回一个由一个字符串组成的单字符字符串,其值是0<=n<=255。如果n[0, 255]之外,但适合64位有符号整数,则chr(n)会引发ValueError,抱怨arg不在range(256)中。如果n不适合64位带符号整数,则chr(n)会引发OverflowError抱怨“ Python int太大,无法转换为C long”(在问题中观察到)

在python 3.x中,如果chr(n)n将返回一个单字符字符串,该字符串由具有值0<=n<0x110000的unicode字符组成。如果n[0, 0x110000)之外但适合32位有符号整数,则chr(n)会引发值错误,抱怨arg不在range(0x110000)中。如果n不适合32位有符号整数,则chr(n)会引发OverflowError抱怨“有符号整数大于最大值”或“有符号整数小于最小值”(取决于n的符号。

在发布的代码中发生这种情况的原因是string.split()在空格处分割了一个字符串,因此for byte in charstr.split()循环仅用byte == charstr执行一次。类似地,''.join([str(bit) for bit in byte]只是说byte(即“通过串联byte的每个字符而产生的字符串”)的很长的路。因此,所讨论的代码将整个113位字符串转换为整数。第一位是1,因此至少需要113位存储它,这意味着它肯定不适合32位或64位有符号整数,因此它属于OverflowError情况2.x和3.x。