首页 >>  正文

excel查找大于一定数值的数据

来源:baiyundou.net   日期:2024-09-21

作者:bluebird118

上篇文章简单介绍了LOOKUP函数的基本应用,如果要全面了解Lookup函数,必须要懂LOOKUP函数的二分法,也就是lookup的查找原理。在这里,我们以上文中的例子来说明,来直接上图:  

这里以江苏省为例上面的公式分别是

=Lookup(A16,A2:B11);=Lookup(E16,E2:F11);

上面相同的公式,具有不同的结果。因此,你看了下面的关于二分法的说明,就能明白其中的缘由。

一、什么是二分法。

一个一个依次进行查找,这就是是遍历法。二分法与之不同。二分法,如其名,二分,或者说是每次对半砍。也就是从二分位处进行查找,若找不到,再从下一个二分位处查找,直到查找到和他大小相同或比它小的数。

二、基本原理。

1、二分位的判定

当总数字是奇数时,二分位很好判定,中间的数字即可。如有9个数(也就是该函数的第二个参数),则第5个数就是中间的数。

如果有10个数呢,则第5个位置是二分位。有一个公式可以计算:=INT((总行数+1)/2)

2、查找方向确定

当在二分位查找不到时,接下来该怎么操作呢?

如果上一次二分位值大于查找的值时,则向上接着查找,找出新的二分位,直到找出对应的值。如下图。

在上图,左边的数据是按照升序来排列的,我们来看右边的数据,查找的值(江苏省的值)是小于二分位值(内蒙古的值),没有找到“江苏省”,公式则会向上找第2个二分位,第2个二分位是天津市(江苏省的值仍然是小于天津市的值),公式仍然会往上找,因上面只有一个值是北京市,所以公式最终返回的值是“京”。

同理,如果数值小于查找的值时,向下继续查找。在这里以查找值(上海市)为例,第1个二分位的值(内蒙古的值是小于上海市的值),方向向下;第2个二分位的值(黑龙江的值仍然是小于上海市的值),方向向下。

如果存在多种重复的值,其中二分值等于查找的值,向下逐个查,直到相邻且相等的值即符合条件。

截止到这里,大家应该能够明白lookup的查找原理,也明白为什么直接利用函数公式,则需要进行排序,排序后,公式返回的结果才是正确的。

今天我们就来了解通过LOOKUP查询返回最后一个满足条件的情况的应用实例。先上菜:

具体公式为=lookup(1,0/(e2:e11=e16),f2:f11)

下面我们来看下具体的原理,原理清楚了,这个公式就好记了,基本上就是一个套路或者说是模板,如果你只想解决问题,那么直接套用即可,可以告诉你100%返回最后一个满足条件对应的结果。

来上大餐(以上文的例子有点不恰当,不过也能说明其中的原理。在这里,就不费脑筋来寻找新的例子):

遇到这种需求,在这里肯定不能直接用Lookup查找江苏省,否则按二分位查找,结果不一定是最后一个。所以就用0除的方法把符合条件的变成0,不符合条变成错误值:

=0/(e2:e11=e16)

结果如下{#DIV/0!;#DIV/0!;#DIV/0!;#DIV/0!;#DIV/0!;#DIV/0!;#DIV/0!;#DIV/0!;#DIV/0!;0}

由于lookup会过滤掉错误值,所以在lookup眼中,上面的数组是这样的:

{0}

然后用1查找最后一个0的位置

=lookup(1,0/(e2:e11=e16),f2:f11)

这里1是任一个大于0的值,因为大于0,所以用二分法查找时,会一直向下查找,直到最后一个0值。

引申一下:

如果数据中存在多个重复数据,可以用上述公式得出最后一个值。同样可以用lookup函数来满足多条件的查找。比如:LOOKUP(1,0/((A2:A9=E2)*(B2:B9=F2)),C2:C9)。在这里需要注意的是Lookup() 多条件查找时无需排序,正常LOOKUP函数要求“查找区域”中的值必须按升序排列,因为是二分法原理,即lookup的二分法查找,是跳跃式的查找。它总认为被查找的1组值是从小到大排列,如果遇到小的就向下找更大的,如果遇到大的就向上找更小的。

","force_purephv":"0","gnid":"9086f741f0a0221f4","img_data":[{"flag":2,"img":[{"desc":"","height":"507","title":"","url":"https://p0.ssl.img.360kuai.com/t01dd827f4f7a276535.jpg","width":"600"},{"desc":"","height":"503","title":"","url":"https://p0.ssl.img.360kuai.com/t01fee8ef8547fb7cdb.jpg","width":"600"},{"desc":"","height":"487","title":"","url":"https://p0.ssl.img.360kuai.com/t013512321d2adef9a0.jpg","width":"600"},{"desc":"","height":"482","title":"","url":"https://p0.ssl.img.360kuai.com/t01d341dfeaee99a472.jpg","width":"600"}]}],"original":0,"pat":"art_src_1,fts0,sts0","powerby":"hbase","pub_time":1673513874000,"pure":"","rawurl":"http://zm.news.so.com/7439bbe02b4bf4091d673f6bd08fa76a","redirect":0,"rptid":"a87df1fdb8961241","s":"t","src":"什么值得买","tag":[],"title":"Excel查找和引用函数LOOKUP函数の二分法

鬱要索4643excel 一栏文字中含有数字,怎么筛选大于某个数字的项 -
张厚居15185802929 ______ 你说的太笼统了,以我的理解如下: =if(a>b,a,0) 先用公式找出大于的项,然后将公式搞成数值,排序,OK

鬱要索4643excel表格选定区域内怎么对大于某值(如大于50)的数计?ex
张厚居15185802929 ______ 直接手动操作,可以使用筛选,筛选出大于50的数值,然后选中之后,07版本以后的EXCEL自动会在最下面显示所选区域个数,03版本需要自己右键最下面边框选择计数. 请采纳我的答案.

鬱要索4643excel 查询数字大小 -
张厚居15185802929 ______ 条件格式,直接选中区域,点格式---条件格式---单元格数值大于800,设置字体为红色,就找出来了啊

鬱要索4643如何从多张excel表中查找一直大于某个数的办法 -
张厚居15185802929 ______ 123456789101112 Subbb() Dimjiage(35) AsInteger'定义价格数组用于存放结果 Form = 1 ToSheets.Count '从第一张工作表循环到最后一张 Forn = 1 To35 '从第一行循环到最后一行 a =sheets(m).Cells(n, 2) '取第n行的第二列数据 Ifa <= 1 Then ...

鬱要索4643在Excel2003版本 中随机找出大于或等于41的数 -
张厚居15185802929 ______ 你可以利用筛选或者高级筛选先把大于等于41的数字筛选出来 比如放在A列=INDEX(A:A,RANDBETWEEN(1,COUNTA(A:A)))下拉就随机找出来了

鬱要索4643在EXCEL2007中,如何在指定区域内查找大于某值数据,并显示出来 -
张厚居15185802929 ______ 选中区域,点条件格式--突出显示单元格规则--大于,输入值或单元格引用.

鬱要索4643在excel中如何找多列的数都大于指定数的个数? -
张厚居15185802929 ______ =sum((成绩区域1>=60)*(成绩区域2>=60)*(成绩区域2>=60)*(成绩区域3>=60))按ctrl+shift+enter结束.

鬱要索4643如何从excel表一列中找出大于等于零的数并求和c1至c20有一列不同的数值,如何从中求出大于等于0的数值这和. -
张厚居15185802929 ______[答案] 以上是数组公式,我觉得用这个函数更好理解一些:(假设数据区域为F1:F25) =SUMIF(F1:F25,">=0",F1:F25)

鬱要索4643在excel里,如何查找多于特定个数(如500个)汉字的表格?谢谢!
张厚居15185802929 ______ 你是说一个单元格里有500个汉字吗? 如果是的话,用公式=len(), 500个汉字就是1000以上,到时候筛选1000以上的就是大于500个汉字的表格

鬱要索4643怎么找到查找符合条件的大于等于某值的最接近值 -
张厚居15185802929 ______ SELECT * FORM tables WHERE price > 10000 and price

(编辑:自媒体)
关于我们 | 客户服务 | 服务条款 | 联系我们 | 免责声明 | 网站地图 @ 白云都 2024