excel if函数区间取数

在单元格取值0~10的数值,若超过10或者低于0都显示为零,如何输入函数,🙏... 在单元格取值0~10的数值,若超过10或者低于0都显示为零,如何输入函数,🙏 展开
 我来答
创作者zUzVB1Sl31
2019-01-05 · 编程类资料、英语学习资料
创作者zUzVB1Sl31
采纳数:1331 获赞数:5975

向TA提问 私信TA
展开全部

你看是不是这种结果:

函数这么写的:

=IF(AND(B2>=INT(LEFT(A2,FIND("~",A2)-1)),B2<=INT(RIGHT(A2,LEN(A2)-FIND("~",A2))))=FALSE,0,B2)

使用函数:

find("字符",值)   获取~符号位置

int(字符)    将字符型数字转换成真正的数字

left,right,len我就不介绍

and(表达式1,表达式2....)=true 并列条件

if(表达式,表达式成立的值,不成立的值)   条件取值

函数较多,另外一种方法就是使用VBA自定义一个函数,我们先新建一个模块

插入函数

'///condition//条件字符串
'///data//存放数据的单元格
Public Function get_value(condition As Range, data As Range)
  Dim min, max '//定义最小值、最大值、数组
  min = Int(Split(Trim(condition.Formula), "~")(0))
  max = Int(Split(Trim(condition.Formula), "~")(1)) '//存储切割着两个值转换格式
  Dim da
  da = Round(Trim(data.Formula), 3) '//获取data里面的值,格式化,取保留三位小数
  If da >= min And da <= max Then '//如果da在min和max之间就取自己的值,如果不是就是0
     get_value = da
  Else
     get_value = 0
  End If
End Function

我们再回去看看函数是否生效

为啥不行了呢?

原因是VBA取值着range.Formula这玩意是单元格字表值,你选择了公式,他就是公式自己写法,不会换算成值的,修改一下:

以上是用EXCEL自身函数和VBA自定义函数,仅供参考!

凌文元LWY
高粉答主

2019-01-05 · 每个回答都超有意思的
知道大有可为答主
回答量:3.6万
采纳率:76%
帮助的人:1.3亿
展开全部
如果数值在B2单元格,那么输入
=IF(AND(B2>=0,B2<=10),B2,0)
或者=IF(OR(B2>10,B2<0),0,B2)
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
童初萌左之和1A
2019-01-05 · TA获得超过2546个赞
知道大有可为答主
回答量:5333
采纳率:82%
帮助的人:900万
展开全部
不能直接写0<a1<40,EXCEL不认识这个,改为
and(a1>0,a1<40)之类的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式