Excel公式match+index匹配教学

需求

假设你有一个办公室位置号码列表,并且需要知道每个办公室中的员工。 电子表格很大,因此你可能会认为它的任务很有挑战性。 使用查找函数实际上非常简单。

官方支持传送门
使用 VVLOOKUP、INDEX 或 MATCH 查找值
如果看不懂的话,没关系,请看下文,VLOOKUP感觉没有MATCH+INDEX好用,这里主要讲述MATCH+INDEX的匹配使用。

MATCH

MATCH官方文档
看不懂的话往下看吧,假如你有一张学生表,里面包含学生姓名,学号和成绩
在这里插入图片描述

表二需要对照表一进行填写,表一是源表,表二是我们的目标表。那么MATCH函数的意义就在根据目标表中的关键字找到源表所在的行数(也就是左边的123344,例如鲁班七号是3),也就是蔡文姬的学号我们用MATCH函数可以得到他在表一的第几行。

  1. 光标定位到F3,点击插入函数
    在这里插入图片描述

  2. 选择MATCH
    在这里插入图片描述

  3. 这三个参数分别是查找值,查找范围,匹配类型
    在这里插入图片描述

  4. 按下enter,F3显示值为10,即蔡文姬在表一的第10行

INDEX

  1. 我们找到了蔡文姬在第几行,但是我们要的是蔡文姬的学号,于是需要用到INDEX进行索引
  2. 我们已经知道了蔡文姬在第10行,所以F3蔡文姬的学号是在A列的第十行也就是1008
  3. 下面请看操作
  4. 我们继续点击F3插入公式INDEX,选择参数第一行即可
    在这里插入图片描述
  5. 这三个参数是查找范围,行数,匹配类型
    在这里插入图片描述

MATCH+INDEX

熟悉了以上操作后,我们来进行综合训练,那么我要查找蔡文姬的学号,公式为

  1. 找到行数
    =MATCH(E3,B:B,0)
    他的结果是10

  2. 找到所在列
    =INDEX(A:A,10,0)
    将10代入

  3. 最终公式
    =INDEX(A:A,MATCH(E3,B:B,0),0)
    在这里插入图片描述

  4. 蔡文姬的成绩则只需将A:A替换成C:C即可
    在这里插入图片描述
    后续更加深入的应用还需继续熟悉,实在记不住就理解下就用鼠标点吧,希望可以帮到有需要帮助的同学。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Elasticsearch 中,可以使用 multi_match 查询来匹配多个字段,然后再使用 match_phrase 查询来进行精确匹配。 具体的代码可以参考下面这个例子: ```java import org.elasticsearch.action.search.SearchRequestBuilder; import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.client.transport.TransportClient; import org.elasticsearch.common.transport.InetSocketTransportAddress; import org.elasticsearch.index.query.BoolQueryBuilder; import org.elasticsearch.index.query.MatchPhraseQueryBuilder; import org.elasticsearch.index.query.QueryBuilders; import org.elasticsearch.index.query.MultiMatchQueryBuilder; TransportClient client = TransportClient.builder().build() .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("localhost"), 9300)); MultiMatchQueryBuilder multiMatchQueryBuilder = QueryBuilders.multiMatchQuery("search phrase", "field1", "field2", "field3"); MatchPhraseQueryBuilder matchPhraseQueryBuilder = QueryBuilders.matchPhraseQuery("field1", "search phrase"); BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery(); boolQueryBuilder.should(multiMatchQueryBuilder); boolQueryBuilder.should(matchPhraseQueryBuilder); SearchRequestBuilder searchRequestBuilder = client.prepareSearch("index_name") .setQuery(boolQueryBuilder) .setSize(10); SearchResponse searchResponse = searchRequestBuilder.get(); ``` 在这个例子中,我们首先创建了一个 MultiMatchQueryBuilder 对象,并通过 addFields 方法来指定要匹配的字段。接着,我们创建了一个 MatchPhraseQueryBuilder 对象,并指定要匹配的字段和精确匹配的搜索词。 然后,我们创建了一个 BoolQueryBuilder 对象,并通过 should 方法来将 multiMatchQueryBuilder 和 matchPhraseQueryBuilder 对象添加到 boolQueryBuilder 中,表示其中一个条件满足即可。 最后,我们将 boolQueryBuilder 对象传入 SearchRequestBuilder 的 setQuery 方法中,完成查询操作。 希望这个例子可以帮助到您。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值