RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 616307
Accepted
Алексей Воронов
Алексей Воронов
Asked:2020-01-18 18:55:28 +0000 UTC2020-01-18 18:55:28 +0000 UTC 2020-01-18 18:55:28 +0000 UTC

如何交换数组元素的字节?

  • 772

有一个数组,其中每个元素都是一个两字节的字。如何交换每个元素的第一个和第二个字节?

python
  • 4 4 个回答
  • 10 Views

4 个回答

  • Voted
  1. diversenok
    2020-01-18T19:52:47Z2020-01-18T19:52:47Z

    数字有点魔力。首先,让我们将一个双字节数字拆分value为两个单字节数字:

    lo = value % 256
    hi = value // 256
    

    现在让我们把它组装回一个两字节的:

    value == hi * 256 + lo # всегда должно быть верно
    rev_value =  lo * 256 + hi # то, что хотим по условию, поменяли байты
    

    因此,如果我们将 shorter 写成一个函数:

    rev_bytes = lambda v: v % 256 * 256 + v // 256
    

    通过将此函数应用于列表的所有元素,例如使用map,我们得到一个完整的解决方案。

    注 1:为了提高性能,这应该按照逻辑位运算来编写,替换i // 256为i >> 8、和:i * 256i << 8+|

    rev_bytes = lambda v: ((v % 256) << 8) | (v >> 8)
    

    注意:注意操作顺序,如果括号放置不正确或根本没有放置,可能会得到意想不到的结果。

    注 2:这里另一个可能的优化是记忆。如果此函数需要多次应用,将所有双字节数字的结果一次保存到一个数组中,并用从该数组中获取所需元素代替函数调用会更快。


    更新:

    假设MyArray有一个存储在 中的双字节数字列表int。然后新数组将如下所示:

    NewArray = list(map(lambda v: ((v % 256) << 8) | (v >> 8), MyArray))
    

    map将对每个元素应用改变字节位置的功能MyArray。list将列出它。

    • 2
  2. Best Answer
    jfs
    2020-01-18T22:31:50Z2020-01-18T22:31:50Z

    给定array一个数组,其中每个元素至少存储两个字节,要更改字节顺序,调用array.byteswap()以下方法就足够了:

    >>> import array
    >>> a = array.array('h', [1, 32767])
    >>> a.tobytes()
    b'\x01\x00\xff\x7f'
    >>> a.byteswap()
    >>> a.tobytes()
    b'\x00\x01\x7f\xff'
    >>> a
    array('h', [256, -129])
    

    可以看出,数字是使用本机字节顺序存储在数组中的(在我的系统上从“最低到最高”sys.byteorder等于)。'little'调用后,.byteswap()字节顺序变为“从高到低”,这改变了存储的值(总是sys.byteorder在解释中):

    >>> import sys
    >>> 1 .to_bytes(2, sys.byteorder)
    b'\x01\x00'  # от "младшего к старшему"
    >>> 1 .to_bytes(2, 'big')
    b'\x00\x01'  # "от старшего к младшему"
    >>> int.from_bytes(_, 'little') # интепретируя как от "младшего к старшему"
    256
    

    相同的 API 适用于numpy数组:

    >>> import numpy
    >>> a = numpy.array([1, 32767], dtype='h')
    >>> a
    array([    1, 32767], dtype=int16)
    >>> a.tobytes()
    b'\x01\x00\xff\x7f'
    >>> a.byteswap(True) # inplace
    array([ 256, -129], dtype=int16)
    >>> a.tobytes()
    b'\x00\x01\x7f\xff'
    

    可以看出,获得了相同的结果。


    如果您有一个带有 Python 数字的 Python 列表[1, 32767],那么字节顺序的概念就没有多大意义。Python int 在内存中的实际表示方式取决于实现,并且与大多数应用程序无关。例如,在CPython中,它int由-sys.int_info.bits_per_digit位数字组成,每个数字占一个sys.int_info.sizeof_digit字节,这些数字从低位到高位,Python绝对值int为:

    SUM(for i=0 through abs(ob_size)-1) ob_digit[i] * 2**(SHIFT*i)
    
    • 2
  3. Denis Leonov
    2020-01-18T19:21:39Z2020-01-18T19:21:39Z
    def reverse(input):
        L = len(input)
        if L%2 <> 0:
            return 'Error' #Ошибка в случае когда L не кратно 2
        else:
            Res = ''
            L = L//2
            for i in range(L):
                T = input[i*2] + input[i*2+1]
                Res = T + Res
                T = ''
            return(Res);
    

    Arr- 你的数字数组(字符串数组,例如A1F6...,在你的情况下,每个字符串的形式)A65D

    调用代码:

    ArrLength = len(Arr)
    for i in range(ArrLength):
        Arr[i] = reverse(Arr[i])
    
    • 1
  4. Arnial
    2020-01-18T19:24:35Z2020-01-18T19:24:35Z

    您可以尝试将 Python 元素“序列化”为二进制 C-s 表示,然后交换字节。

    我假设元素存储为数字。

    from struct import pack, unpack
    
    def reorder_bytes( value ):
        return unpack( "H", pack( "H", value )[::-1] )[0]
    
    
    # модуль struct используется для конвертации С структур в python объекты
    # H --- unsigned int16
    # pack с "H" сконвертирует python int в бинарную строку длиной в 2 байта, соответствующую Си представление unsigned int16
    # unpack возвращает tuple из распакованных данных, нужный нам результат будет в первом элементе.
    
    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5