前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Excel公式练习72: 提取大写字母创建缩写

Excel公式练习72: 提取大写字母创建缩写

作者头像
fanjy
发布2020-07-24 10:06:44
1.8K0
发布2020-07-24 10:06:44
举报
文章被收录于专栏:完美Excel完美Excel

学习Excel技术,关注微信公众号:

excelperfect

导语:本次的练习整理自myspreadsheetlab.com,可以很好的帮助我们练练手!

本次的练习是:如下图1所示,使用公式,提取列A每个单元格数据中的大写字母。

图1

满足以下条件:

  • 只提取大写字母
  • 每个单词以大写字母开始
  • 每个单词仅有一个大写字母
  • 单元格中的数据文本可能包含空格,也可能没有空格
  • 单元格中的数据文本只包含字母和空格
  • 单元格中的数据文本可包含任意类型的字符
  • 大写字母中没有重音符号
  • 数据所在的工作表名为“x”(仅1个字符)
  • 结果长度必须等于大写字母的数量
  • 公式要最短

先不看答案,自已动手试一试。

解决方案

首先,提取每一字符,使用CODE函数将其转换成对应的数字,如果数字大于等于65且小于等于90,将该数字再转换成对应的字母,将大写字母连在一起。

公式中,MID(x!A5,ROW(INDIRECT("1:"&LEN(x!A5))),1)用于提取单个字符,也可以使用MID(A5,ROW(A$1:INDEX(A:A,LEN(A5))),1),但前者更短。CODE函数将字符转换成相应的数字,注意大写字母编码从65至90。IF函数将忽略我们不想要的编码。CHAR函数将数字转换成字母。CONCAT函数将提取到的大写字母连接。

公式1:

=SUBSTITUTE(CONCAT(CHAR(IF((CODE(MID(A5,ROW(INDIRECT("1:"&LEN(A5))),1))>64)*(CODE(MID(A5,ROW(INDIRECT("1:"&LEN(A5))),1))<91),CODE(MID(A5,ROW(INDIRECT("1:"&LEN(A5))),1)),91))),"[","")

公式2:

=SUBSTITUTE(CONCAT(IFERROR(CHAR(IF(CODE(MID(A5,ROW(INDIRECT("1:"&LEN(A5))),1))<91,CODE(MID(A5,ROW(INDIRECT("1:"&LEN(A5))),1)))),"")),"","")

公式3:

=SUBSTITUTE(CONCAT(IFERROR(CHAR(IF(z<91,z)),"")),"","")

其中,“z”是一个定义的名称:

名称:z

引用位置:=CODE(MID(x!A5,ROW(INDIRECT("1:"&LEN(x!A5))),1))

公式4:

=SUBSTITUTE(CONCAT(IFERROR(CHAR(IF(AND(z<91,z>64),z)),"")),"","")

与公式3相同,“z”是一个定义的名称。

公式5:

=CONCAT(FILTER(MID(A5,SEQUENCE(LEN(A5)),1),ISNUMBER(MATCH(CODE(MID(A5,SEQUENCE(LEN(A5)),1)),SEQUENCE(24,,65),0))))

公式6:

=TEXTJOIN("",1,IF(ISNUMBER(MATCH(CODE(MID(A5,ROW(INDIRECT("1:"&LEN(A5))),1)),ROW(INDIRECT("65:90")),0)),MID(A5,ROW(INDIRECT("1:"&LEN(A5))),1),""))

公式7:

=SUBSTITUTE(CONCAT(IFERROR(CHAR(IF(CODE(MID(A5,ROW(A1:INDEX(A:A,LEN(A5))),1))<91,CODE(MID(A5,ROW(A

本文只给出了公式的基本运行原理和公式,有兴趣的朋友可以参考本系列前面讲解的一些方法对公式进行调试,以加深理解。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-07-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 完美Excel 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档