5

我在使用 find()/index() (不知道它们之间是否有任何区别)和 bytesarray 时遇到了这个奇怪的问题。

我正在使用二进制文件,我已将其加载为字节数组,现在我需要找到指示消息开始和消息结束的标记。找到消息的开头(0x03 0x02)一切正常,但是当我搜索结尾(0x00)时,我一直得到相同的位置

    msg_start_token = bytearray((int(0x03), int(0x02)))
    msg_end_token = bytes(int(0x00))

    def get_message(file,start_pos):
        msg_start = file.find(msg_start_token,start_pos) + 2
        print(hex(msg_start))
        msg_end = file.find(msg_end_token,msg_start)
        print(hex(msg_end))
        msg = file[msg_start:msg_end]
        print(msg)
        return (msg, msg_end)  

我以前没有真正使用过二进制文件,所以我不知道我是否错过了一些非常简单的东西。

4

1 回答 1

4

您需要从下一个位置开始搜索,因此搜索:

file.find(msg_start_token, start_pos + 1)

因为搜索从 开始 start_pos如果msg_start_token在那个位置找到, findstart_pos当然会返回。

.index()至于和之间的区别.find();如果未找到子字符串,则.index()引发异常,而返回。ValueError.find()-1

于 2013-02-07T13:11:13.473 回答