text1=1.58 a=2.0
text1=1.48 a=1.5
text1=2.98 a=3.0
text1=2.11 a=2.5
text1=-1.58 a=-2.0
text1=-1.48 a=-1.5
text1=1.00 a=1.0
求a的函数
小数点尾数是 .0 或 .5
小数点不能是其他的数字
VB四舍五入
答案:3 悬赏:70
解决时间 2021-11-09 11:22
- 提问者网友:冥界祭月
- 2021-11-09 03:25
最佳答案
- 二级知识专家网友:堕落奶泡
- 2021-11-09 04:32
Private Sub Command1_Click()
Dim a As Single
a = Round(Val(Text1.Text), 1) '四舍五入到小数点后一位:1.58运算结果为1.6,1.48结果为1.5
If Right(Format(a, "#.#"), 1) <> "5" Then '判断小数点后一位是否等于5
a = Round(a) '若大于五,四舍五入到整数:1.6为2,1.5不满足条件,不运算
End If
Print Format(a, "0.0") '输出a,格式保留小数点后一位:2输出2.0,1.5还是输出1.5
End Sub其他结果都对,但 text1=2.11 a=2.5 时,结果应该为a=2.0,你是怎么算出结果2.5的?
不知道你的逻辑是什么,下面一段代码可以满足你要求,具体用上一段还是下一段,你自己决定:
Private Sub Command1_Click()
Dim a As Single
a = Round(Val(Text1.Text), 1) '四舍五入到小数点后一位
If Right(Format(a, "#.#"), 1) > "5" Or Right(Format(a, "#.#"), 1) = "." Then '判断小数点后一位是否大于5或等于0
a = Round(a) '若大于五,四舍五入到整数
Else
a = Val(Str(Fix(a)) & 0.5) '若小于5且不等于0,则取整,为了省略判断正负号,所以直接转换为字符串处理,再转换回数字类型
End If
Print Format(a, "0.0") '输出a,格式保留小数点后一位
End Sub
Dim a As Single
a = Round(Val(Text1.Text), 1) '四舍五入到小数点后一位:1.58运算结果为1.6,1.48结果为1.5
If Right(Format(a, "#.#"), 1) <> "5" Then '判断小数点后一位是否等于5
a = Round(a) '若大于五,四舍五入到整数:1.6为2,1.5不满足条件,不运算
End If
Print Format(a, "0.0") '输出a,格式保留小数点后一位:2输出2.0,1.5还是输出1.5
End Sub其他结果都对,但 text1=2.11 a=2.5 时,结果应该为a=2.0,你是怎么算出结果2.5的?
不知道你的逻辑是什么,下面一段代码可以满足你要求,具体用上一段还是下一段,你自己决定:
Private Sub Command1_Click()
Dim a As Single
a = Round(Val(Text1.Text), 1) '四舍五入到小数点后一位
If Right(Format(a, "#.#"), 1) > "5" Or Right(Format(a, "#.#"), 1) = "." Then '判断小数点后一位是否大于5或等于0
a = Round(a) '若大于五,四舍五入到整数
Else
a = Val(Str(Fix(a)) & 0.5) '若小于5且不等于0,则取整,为了省略判断正负号,所以直接转换为字符串处理,再转换回数字类型
End If
Print Format(a, "0.0") '输出a,格式保留小数点后一位
End Sub
全部回答
- 1楼网友:旧事诱惑
- 2021-11-09 07:10
a = Round(Text1.text , 1)
- 2楼网友:单身小柠`猫♡
- 2021-11-09 05:54
a=fix(val(text1.text)*10)/10
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯