所以我得到了以下代碼:telegram = "$00;02;A1;00000000*49"checksum = telegram[10:18] # is 00000000for x in telegram[1:]: x = "{0:08b}".format(int(hex(ord(x)),16)) print (x)它輸出字符串每個字符的二進制值telegram:0011000000110000001110110011000000110010001110110100000100110001001110110011000000110000001100000011000000110000001100000011000000110000001010100011010000111001現在我想獲得電報的校驗和,這意味著我必須使用按位運算符^。我確實得到了這樣的正確結果:#--snip--firstdigit = "{0:08b}".format(int(hex(ord(telegram[1])),16)) # telegram[1] = 0result_1 = int(firstdigit) ^ int(checksum)print (f'{result_1:08}') # is 00110000seconddigit = "{0:08b}".format(int(hex(ord(telegram[2])),16)) # telegram[2] =0result_2 = int(result_1) ^ int(seconddigit)print (f'{result_2:08}') # is 00000000 thirddigit = "{0:08b}".format(int(hex(ord(telegram[3])),16)) # telegram[3] =;result_3 = int(result_2) ^ int(thirddigit)print (f'{result_3:08}') # is 00111011 ...等等。(正確)輸出:001100000000000000111011但這樣做似乎真的很不方便,這讓我遇到了實際問題:我想循環遍歷字符串telegram以獲得所需的輸出,但我就是無法掌握它。如果您能幫助我,我將非常感激!
1 回答

慕碼人2483693
TA貢獻1860條經驗 獲得超9個贊
您可以使用每個字符上的函數跳過到二進制字符串的轉換ord()。例如:
>>> telegram = "$00;02;A1;00000000*49"
>>> ord(telegram[1]) ^ ord(telegram[2])
0
您可以使用列表理解將所有字符轉換為序數:
>>> [ord(n) for n in telegram[1:]] # all but first character...
[48, 48, 59, 48, 50, 59, 65, 49, 59, 48, 48, 48, 48, 48, 48, 48, 48, 42, 52, 57]
使用標準庫中的工具(例如functools.reduce和operator.xor),您可以將所有值異或在一起:
>>> import functools
>>> import operator
>>> functools.reduce(operator.xor,[ord(n) for n in telegram[1:]])
110
>>> format(110,'08b') # binary if needed
'01101110'
- 1 回答
- 0 關注
- 203 瀏覽
添加回答
舉報
0/150
提交
取消