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)];

}

}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-05-23

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码

本回答被网友采纳
第2个回答  2019-07-08

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码

本回答被网友采纳
第3个回答  推荐于2017-11-23
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了!本回答被提问者采纳
第4个回答  2022-09-01

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        ;程序结束

相似回答