| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
共有 1537 人关注过本帖
标题:有关于单精度小数在excel中的累加问题
取消只看楼主 加入收藏
rootsucn
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2010-8-31
结帖率:28.57%
收藏
已结贴  问题点数:20 回复次数:2 
有关于单精度小数在excel中的累加问题
Private Sub Timer1_Timer()
   
    Static ElapsedTime As Single
    ElapsedTime = ElapsedTime + 0.1
    If LeftPictureBox_RUNNING = True Then
    Buffer = ElapsedTime & "," & CoordinatesX & "," & CoordinatesY   
    ElseIf RightPictureBox_RUNNING = True Then
    Buffer = ElapsedTime & "," & "," & "," & CoordinatesX & "," & CoordinatesY   
    End If
    TxtFile.WriteLine (Buffer)
End Sub

如图所示,在Timer中进行每次0.1的累加,结果竟然到了2.7的时候,2.7+0.1变成了2.799999
如何解决该问题,敬请各位大侠不吝赐教!!!
图片附件: 游客没有浏览图片的权限,请 登录注册

2010-09-07 14:12
rootsucn
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2010-8-31
收藏
得分:0 
回复 2楼 风吹过b
非常感谢您的回答。
可是
这个文件是我以
    Set FSO = CreateObject("Scripting.FileSystemObject")
    Set TxtFile = FSO.CreateTextFile(Year(Date) & "擭" & Month(Date) & "寧" & Day(Date) & "擔" & "(" & WeekdayName(Weekday(Date), True) & ") " & Hour(time) & "帪" & Minute(time) & "暘" & ".csv", True)
    TxtFile.WriteLine "Time(s),X(Left),Y(Left),X(Right),Y(Right)"
    Timer1.Enabled = True

这种形式定义生成的
如何在生成之初,就不产生这种99999999999的小数呢??
还有,请问为何会产生这种99999999999的小数??

恳请不吝赐教!!!
2010-09-07 17:07
rootsucn
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2010-8-31
收藏
得分:0 
回复 4楼 风吹过b
您真是高人啊!!!!
不胜感激 ~~~
2010-09-08 15:08
快速回复:有关于单精度小数在excel中的累加问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019396 second(s), 11 queries.
Copyright©2004-2025, BC-CN.NET, All Rights Reserved