微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python:将列表中已有的项目分组并反转它们

如何解决Python:将列表中已有的项目分组并反转它们

我有一个像这样的二进制文件

00 01 02 04 03 03 03 03 00 05 06 03 03 03 03 03 00 07 03 03 03 03 03 03 ...

我想每组 8 个项目

[00 01 02 04 03 03 03 03] [00 05 06 03 03 03 03 03] [00 07 03 03 03 03 03 03]...

然后像这样反转每个组内的项目:

[03 03 03 03 04 02 01 00] [03 03 03 03 03 06 05 00] [03 03 03 03 03 03 07 00]

我尝试过 reverse() 但它反转了所有列表。

我想象过这样的事情:在循环中我应该数到 8(或 7),创建一个组,反转它,然后增加行,数 8,反转等等,但我不能编码。

我试过了

i=0
for item in (list_reverse):
    i+=1
    if i>8:
        list_reverse.reverse()
        i=0

但它不起作用。

也许我应该尝试嵌套循环?

解决方法

.split() 字符串,然后遍历它。

t = """00 01 02 04 03 03 03 03
00 05 06 03 03 03 03 03
00 07 03 03 03 03 03 03"""
out = ""
lines = t.split("\n")
for n,line in enumerate(lines):
    lst = line.split(" ")
    c = 0
    reversed_lst = ""
    while c < len(lst):
        reversed_lst += (lst[len(lst)- c -1]) + " "; c+=1 
    if n != len(lines) - 1:
        out += reversed_lst + "\n"
    else:
        out += reversed_lst
print(out)      

输出:

03 03 03 03 04 02 01 00 
03 03 03 03 03 06 05 00 
03 03 03 03 03 03 07 00 
,

这是 Python 内置 bytearray 的一个很好的用例。首先,您可以打开二进制输入文件并使用 bytearray 存储其内容:

with open("binary.file","rb") as f:
    bytes = bytearray(f.read())

然后,我们将使用您的算法循环遍历字节并将它们存储在一个名为 group(它也是一个 bytearray)的变量中,每 8 次迭代:

i = 0
groups = []
group = bytearray()
for byte in bytes:
    i += 1
    group.append(byte)
    if i == 8:
        groups.append(group)
        i = 0
        group = bytearray()

就像快速的完整性检查一样,测试变量 i 的值,因为如果它现在不为零,那么最后一组将少于 8 个字节长:

if i != 0:
    raise EOFError("Input file does not align to 8 byte boundary!")

最后,我们将反转每个组并打印输出:

for group in groups:
    group.reverse()

print(groups)

根据您的用例,您还可以连接反向字节并将它们存储在另一个文件中,甚至覆盖同一个文件。尽管我的猜测是,如果您对任何普通的二进制文件(如 JPEG 或 EXE)执行此操作,您将完全破坏它们。幸运的是,您可以再次运行该程序来恢复它们!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。