BCD码转换成ASCII值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BCD码转换成ASCII值相关的知识,希望对你有一定的参考价值。

我想问下各位大侠,压缩的BCD码要转换成两个ASCII值,应该怎么转换?我想知道转换的原理,请用文字给我描述下啊,直接上程序我看不明白。

voidWhAsciiToBcd(unsignedchar*psDataIn,size_tuiDataInLen,unsignedchar*psDataOut)

unsignedcharucTemp=0;

for(size_ti=0;i<uiDataInLen;i+=2)

ucTemp=psDataIn[i];

if(ucTemp>'9')

ucTemp=(unsignedchar)toupper((unsignedchar)ucTemp)-'A'+0x0A;

else

ucTemp&=0x0F;

psDataOut[i/2]=ucTemp<<4;

ucTemp=psDataIn[i+1];

if(ucTemp>'9')

ucTemp=(unsignedchar)toupper((unsignedchar)ucTemp)-'A'+0x0A;

else

ucTemp&=0x0F;

psDataOut[i/2]|=ucTemp;

扩展资料

ASCII转BCD

voidWhBcdToAscii(unsignedchar*psDataIn,size_tuiDataInLen,unsignedchar*psDataOut)

unsignedcharsAscii[]="0123456789ABCDEF";

for(size_ti=0;i<uiDataInLen;i++)

psDataOut[2*i]=sAscii[(psDataIn[i]>>4)];

psDataOut[2*i+1]=sAscii[(psDataIn[i]&0x0F)];

参考技术A

BCD码转ASCII码:

BCD码表示:对于用BCD码怎么表示十进制数29上面已经分析的非常清楚了,这里不赘述了。十进制数29 === BCD码表示为:0010 1001

转换过程:可以直接转换。BCD码  0010 转换成ASCII码就直接加上 十六进制数0x30(十进制为48)就可以了,这个差值可以根据ASCII和十进制数换算下。同样的各位上的数也相加下就可以了。

C代码表示:#define BCD_TO_ASCCII(val)    (((((val) >> 8) + 0x30) << 8) +  (((val) & 0xFF) + 0x30))。

扩展资料:

BCD码可分为有权码和无权码两类:有权BCD码有8421码、2421码、5421码,其中8421码是最常用的;无权BCD码有余3码,余3循环码等。

8421 BCD码是最基本和最常用的BCD码,它和四位自然二进制码相似,各位的权值为8、4、2、1,故称为有权BCD码。

和四位自然二进制码不同的是,它只选用了四位二进制码中前10组代码,即用0000~1001分别代表它所对应的十进制数,余下的六组代码不用。

参考资料来源:百度百科-BCD码

参考技术B

BCD码转ASCII码

BCD码表示:对于用BCD码怎么表示十进制数29上面已经分析的非常清楚了,这里不赘述了。十进制数29 === BCD码表示为:0010 1001

转换过程:可以直接转换。BCD码  0010 转换成ASCII码就直接加上 十六进制数0x30(十进制为48)就可以了,这个差值可以根据ASCII和十进制数换算下。同样的各位上的数也相加下就可以了。

C代码表示:#define BCD_TO_ASCCII(val)    (((((val) >> 8) + 0x30) << 8) +  (((val) & 0xFF) + 0x30))。


扩展资料

BCD码可分为有权码和无权码两类:有权BCD码有8421码、2421码、5421码,其中8421码是最常用的;无权BCD码有余3码,余3循环码等。

bcd码通常是指8421码就是将十进制的数以8421的形式展开成二进制,大家知道十进制是0~9十个数组成,这十个数每个数都有自己的8421码。

bcd码是四位二进制码, 也就是将十进制的数字转化为二进制, 但是和普通的转化有一点不同, 每一个十进制的数字0-9都对应着一个四位的二进制码,对应关系如下: 十进制0 对应 二进制0000 ;

十进制1 对应二进制0001 ....... 9 1001 ,接下来的10就有两个上述的码来表示 10,表示为00010000 也就是BCD码是遇见1001就产生进位,不象普通的二进制码,到1111才产生进位10000。

压缩BCD码与非压缩BCD码的区别—— 压缩BCD码的每一位用4位二进制表示,一个字节表示两位十进制数。例如10010110B表示十进制数96D;

非压缩BCD码用1个字节表示一位十进制数,高四位总是0000,低4位的0000~1001表示0~9.例如00001000B表示十进制数8。

参考资料:百度百科-BCD码

参考技术C bcd码通常是指8421码就是将十进制的数以8421的形式展开成二进制,大家知道十进制是0~9十个数组成,这十个数每个数都有自己的8421码
bcd码是四位二进制码, 也就是将十进制的数字转化为二进制, 但是和普通的转化有一点不同, 每一个十进制的数字0-9都对应着一个四位的二进制码,对应关系如下: 十进制0 对应 二进制0000 ;十进制1 对应二进制0001 ....... 9 1001 接下来的10就有两个上述的码来表示 10 表示为00010000 也就是BCD码是遇见1001就产生进位,不象普通的二进制码,到1111才产生进位10000

压缩BCD码与非压缩BCD码的区别—— 压缩BCD码的每一位用4位二进制表示,一个字节表示两位十进制数。例如10010110B表示十进制数96D;非压缩BCD码用1个字节表示一位十进制数,高四位总是0000,低4位的0000~1001表示0~9.例如00001000B表示十进制数8.
百度百科http://baike.baidu.com/view/45179.htm?fr=ala0_1_1

BCD码代表数字0~9,ASCII码中也有代表数字0~9的码元,可以查看ASCII表,'0'=48,'1'=49,依次类推。
先把压缩BCD拆开变成非压缩BCD,然后加48就是ASCII中的0~9了!本回答被提问者采纳
参考技术D

8421BCD 码,加上 30H,即转换成了 ASCII 码。

压缩的BCD码,只要除以 16,即可分解成两个“非压缩的BCD码”。

然后,分别加上 30H 即可完成转换。

这么简单的事,如果动用 C 语言,就太累人了。

汇编语言的例程如下:

 MOV A,#58H ;任取压缩的BCD码 00~99H

 MOV B,#16

 DIV AB     ;分解完成

 OR A,#30H  ;分别加30H

 OR B,#30H  ;转换完毕

END        ;程序结束

十进制数如何换算成8421BCD码

十进制数如何换算成8421BCD码

把一位十进制数,转换成二进制,再凑足四位,即可。

参考技术A

十进制数换算成8421BCD码的方法如下:

1、十进制换算BCD码,整数从右边开始,每个数是4位二进制代码。比如:(195)10=(1 1001 0101)BCD,小数和其他进制转换不一样,是数位换算:(0.28)10=(0.0010 1000)BCD。

BCD码换算成十进制数的方法如下:

1、BCD码与十进制数的转换关系很直观,相互转换也很简单,将十进制数75.4转换为BCD码:7->0111,5->0101,4->0100所以拼成8421BCD码的结果是:(0111 0101.0100)BCD;若将BCD码1000 0101.0101转换为十进制数:1000->8,0101->5,0101->5所以结果是:(85.5)D。

二进制编码的十进制数,简称BCD码(Binarycoded Decimal)。

这种方法是用4位二进制码的组合代表十进制数的0,1,2,3,4,5,6 ,7,8,9 十个数符。4位二进制数码有16种组合,原则上可任选其中的10种作为代码,分别代表十进制中的0,1,2,3,4,5,6,7,8,9 这十个数符。最常用的BCD码称为8421BCD码,8.4.2.1 分别是4位二进数的位取值。

以上是关于BCD码转换成ASCII值的主要内容,如果未能解决你的问题,请参考以下文章

请问这个C51中的这个函数可以把BCD码转换成十进制,具体原理是怎么执行的呀

8421BCD码怎样转换成十进制

二进制怎样转换成8421BCD码?

BCD码怎么转换成标准二进制形式?

十进制数如何换算成8421BCD码

8421bcd码1111011转换成十进制