- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
二进制字段的描述是:
Caller number, expressed with compressed BCD code, and the surplus bits are filled with “0xF”
我尝试使用结构格式 '16c'
打印,我得到:('3', '\x00', '\x02', '\x05', '\x15', '\x13', 'G', 'O', '\xff', '\xff', '\xff', '\xff', '\xff', '\xff', '\xff' , '\xff')
如果我使用 '16b'
我会得到 (51, 0, 2, 5, 21, 19, 71, 79, -1, - 1, -1, -1, -1, -1, -1, -1)
。它不正确,我应该得到电话号码,上面的号码无效。
print struct.unpack_from('>16b', str(data.read()),offset=46)
上面的代码不起作用,我得到了无效的数字。我应该用什么格式解压那个 16 字节的字段以及如何转换 BCD 码?
最佳答案
BCD 代码使用每个数字 4 位,通常只对数字 0 - 9 进行编码。因此序列中的每个字节包含 2 个数字,每 4 位信息 1 个。
以下方法使用生成器生成这些数字;我假设 0xF 值表示后面没有更多数字:
def bcdDigits(chars):
for char in chars:
char = ord(char)
for val in (char >> 4, char & 0xF):
if val == 0xF:
return
yield val
这里我使用了一个 right-shift operator将最左边的 4 位向右移动,并且 bitwise AND只选择最右边的 4 位。
演示:
>>> characters = ('3', '\x00', '\x02', '\x05', '\x15', '\x13', 'G', 'O', '\xff', '\xff', '\xff', '\xff', '\xff', '\xff', '\xff', '\xff')
>>> list(bcdDigits(characters))
[3, 3, 0, 0, 0, 2, 0, 5, 1, 5, 1, 3, 4, 7, 4]
该方法适用于 c
输出;如果直接传递整数,则可以跳过方法中的 ord
调用(但改用 B
无符号变体)。或者,您可以直接从文件中读取这 16 个字节,并将此函数直接应用于这些字节,而无需使用结构。
关于Python,如何解码二进制编码的十进制(BCD),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11668969/
今天我在正则表达式中偶然发现了一个奇怪的行为——匹配。我无法解释,尽管我认为我对正则表达式很有经验 print re.sub('a*|b', '', 'bcd') bcd 没有 glob 的地方 p
我有一个由 CashRegister Machine 创建的 Hex 文件。我必须读入这个文件。 文件使用下面详述的格式。它就像套接字数据包。 代码数据:2字节 PLU码数据:7字节 单价数据:5字节
我问了这个问题,Matching if all of BCD..n exist after last occurrence of A就在昨天,我们得到了快速而准确的答案(请参阅regex demo)。
我正在向左或向右移动 BCD 数字的位以快速乘以或除以 2。这是一个左移的快速示例: void LShift(unsigned char *arg) { int i, carry=0, temp
使用“Arduino 语言”(C++ 包装器)的 Arduino 项目 - 我有一个 8 字符数组,它以 {'H','H',':','M','M',':','S,'S 的形式提供 24 小时时钟'}
我有一个包含以下值的无符号字符数组:“\x00\x91\x12\x34\x56\x78\x90”;那是以十六进制格式发送的数字。此外,它是 BCD 格式:字节为 00,另一个字节为 91(8 位) 另
如何在不使用 sprintf 的情况下在 C 中实现这些转换? 20 => 0x20 12 => 0x12 目前我有: int year = 12; int month = 10; int day =
A、B、C 和 D 代表正则表达式的不同部分。 我要达到的效果:输入字符串为 ACD 或 BCD。用E替换C后,输出应该是AED或BED。 我使用的正则表达式: r=(A)C(D)|(B)C(D) 但
二进制字段的描述是: Caller number, expressed with compressed BCD code, and the surplus bits are filled with “
有人可以向我解释如何将BCD转换为十六进制吗?例如,如何将98(BCD)转换为十六进制。 谢谢。 最佳答案 我不太了解您的问题,但我猜是有人给您一个以BCD编码的数字98,该数字是: 1001 100
这是我努力尝试但无法解决的问题。 我从试卷上抓到了问题,我在考试中无法解决它,而其他学生也无法解决。 你可能会问,你为什么不问问你的讲师(这是一个公平的问题,因为你不是来解决考试问题或家庭作业的),我
我正在寻找现有的 Delphi Data.FmtBcd 库的替代品,因为我刚刚达到了它的限制,例如它可以表示的最大十进制数字,并且程序因 EBcdOverflowException 终止。出于好奇,我
如果您不了解二进制,我知道 BCD 是更直观的数据类型。但我不知道为什么要使用这种编码,它好像没有多大意义,因为它浪费以 4 位表示(当表示大于 9 时)。 另外,我认为 x86 仅支持直接添加和替换
我应该如何将包含十六进制值的 uint8 数组转换为打包的 bcd 值?简单地调动 4 个位置就能完成工作吗?如果可能的话,我希望提供一些代码示例以更好地理解我的问题 最佳答案 以下代码是如何转换的示
我是一名学习 C++ 的初学者(自学)程序员,最近我决定实现一个二进制编码的十进制 (BCD) 类作为练习,这样我就可以在 Project Euler 上处理非常大的数字。 .我想尽可能从根本上做到这
我正在寻找更好的方法来优化此功能以获得更好的性能,加快其针对嵌入式设备的目标。我欢迎任何指点,建议谢谢 函数将字符串BCD转为十进制 int ConvertBCDToDecimal(const std
我现在解决这个问题太蠢了...... 我得到一个BCD码(每个数字都是自己的4Bit表示) 比如我想要的: 输入:202(十六进制)== 514(十进制) 输出:BCD 0x415 输入:0x202
在我的项目中使用的值是用4位二进制编码的十进制数(BCD)表示的,它最初存储在一个字符缓冲区中(例如,由指针指向 const unsigned char *) .我想将输入的 BCD 字符流转换为整数
我正在寻找一种将字符串转换为等效 BCD 码的方法。我使用Java,但这确实不是语言的问题。我试图逐步了解如何将字符串转换为 BCD。 例如,假设我有以下字符串; "0200" (This strin
我知道您可以使用此表将十进制转换为 BCD: 0 0000 1 0001 2 0010 3 0011 4 0100 5 0101 6 0110 7 0111 8 1000 9 1001 此转换是否有方
我是一名优秀的程序员,十分优秀!