如何把如float 类型的12.5转化成字符串格式以便在1602上显示12.5?求高手告知,最好能具体给个简单的例子。
c语言的谢谢
//---------------------------------------------------
void W_LCD_X1_Dat(uint sec)
{
W_LCD_Com(0xc0 + 6);
W_LCD_Dat(0x30 + sec / 10000);
W_LCD_Dat(0x30 + (sec % 10000) / 1000);
W_LCD_Dat(0x30 + (sec % 1000) / 100);
W_LCD_Dat(0x30 + (sec % 100) / 10);
W_LCD_Dat('.');
W_LCD_Dat(0x30 + sec % 10);
}
//---------------------------------------------------
void main()
{
float aaa;
uint bbb;
init();
aaa = 12.5;
bbb = aaa * 10;
W_LCD_X1_Dat(bbb);
while(1);
}
//=========================================
初始化等函数,可见:
http://hi.baidu.com/%D7%F6%B6%F8%C2%DB%B5%C0/blog/item/e9a4f10963e835c463d98677.html
显示画面如下:
追问呵呵,你这个是知道小数点后几位可以,如果位数未知就要先判断有几位,这样程序写起来很复杂
追答在某个项目中,要求显示几位小数,应该是很明确的,不用判断。
通常,显示数字,四位就是很精密的了,常用是用三位显示。
那么,整数部分如果是0~9,仅仅需要显示2位小数;
整数部分如果是10~99,仅仅需要显示1位小数;
整数部分如果是100~999,就不显示小数。
可以说:真没有什么可判断的。
比使用字符转换函数什么的,要简单多的多了。
哈哈,这个精度太差了。不适合计算器,倒是对有些ad转换后显示结果可以,比方说ds18b20
做的温度计可以
你的题目要求仅仅是显示,怎么精度差?
内部计算,你愿意用几位,就用几位,没有精度差的问题。
单片机是用来作工控产品的,四位显示就够用。
用单片机做计算器,痴人说梦吧,这产品卖不出去的。
嗯我做的不是产品只是练习一下程序,谢谢你了
追答碰上循环小数,你还想要显示起来没有完吗?
应该显示多少位数,你自己规定即可。
如果你嫌精度差,你就多显示几位呗。
怎么可能是这个程序的精度差?
提问者,很明显,基本概念不清。
要是使用下面在步骤:
--把数字转化成字符放入数组,
--然后再通过调用函数转化成长整型,
--再把这个长整型可以用sprintf函数转化成字符
呵呵,真想像不出来,还有没有更笨的方法了。
花费单片机大量的时间,再多绕几个圈,也不会比本程序的精度高。
这样好像不行,因为sprintf直接转数字如111,跟本转不成“111”
追答怎么会呢?我仿真在str中看到的就是ASCII码,你的1602不支持吗?
追问我用keil c软件做的。我当初就是卡在这个地方了,后来我发现这么做可以,就是先把输入的数字转化成字符放入数组,然后再通过调用函数转化成长整型,再把这个长整型可以用sprintf函数转化成字符没有错误
追答我可能明白了,你对小数点的精度有要求是吧。单片机的C语言中如果使用标准数据类型,小数精度不可能很高(映像中好像是6、7位,其实也不算低了)。如果你想实现很高的精度,恐怕还是要采用多个long型的变量,自己编写算法(比如16位数的四则运算,很痛苦...)。输出处理上正如你所说,拼装成字符串后再输出。
关于使用sprintf,这是KEIL C自带的扩展函数,本身应该是没有问题的,输出不对可能与输出格式转换字符的写法有关。其实float型的很简单:
%f:x.xxx方式
%e:xxxxExx方式
%g:所谓的自动选择上述两种方式中更紧凑的一种作为输出格式。
希望对你有所借鉴。
你的程序我看了,算法倒是行,我想问一下,你这个算法在被除数无法被除数整除的时候结果是不是不能显示小数位?