超全面使用方法! WPS表格更新的16个新函数个个都是yyds
脚本之家
最近几个月新函数很多,有个别是WPS表格特有的,大部分Office365也可以用,全部整理到一起,一共16个,方便学习。所有公式都是直接输入后,回车即可,不需要像旧版本的数组那样按三键。
1、将一列内容转换成多列(WRAPCOLS和WRAPROWS)
这种有2个新函数处理,语法一样。
一个是先按列排序。
=WRAPCOLS(A2:A26,5)
一个是先按行排序。
=WRAPROWS(A2:A26,5)
2、将多行多列转换成一列或一行(TOCOL和TOROW)
TOCOL是转换成一列。
=TOCOL(A1:E5)
TOROW是转换成一行,转成行的不直观,平常几乎不用。
=TOROW(A1:E5)
假如多行多列内容里面存在错误值或者空单元格,可以设置第二参数为3忽略。2个函数的用法一样。
=TOCOL(A1:E5,3)
3、根据工作表名称生成目录SHEETSNAME一个简单的函数即可,而Office需要很复杂的公式或者VBA才行。
=SHEETSNAME(,1)
4、正则表达式REGEXP,提取各种内容两个软件都有正则,而Office是由3个函数组成。
将字符串的数字、文字分离
[0-9]+代表连续的数字。
=REGEXP(A2,"[0-9]+")
^就是非的意思,[^0-9]+代表不是数字,也就是剩下的文字。
=REGEXP(A2,"[^0-9]+")
也可以用[一-龟]+。
=REGEXP(A2,"[一-龟]+")
5、将同一个单元格的内容拆分到多个单元格TEXTSPLIT
=TEXTSPLIT(A1," ",CHAR(10))
有的时候会出现输入不规范,也就是同时存在不同分隔符号,比如现在有空格和横杆存在。
正常人的思维,用查找替换,将符号统一。经过了测试,发现这个函数,即使不统一也行,分隔符号可以同时输入多个符号。{" ","-"},也就是{"符号1","符号2"}。
=TEXTSPLIT(A1,{" ","-"},CHAR(10))
6、用UNIQUE函数就可以提取不重复
只需在一个单元格输入公式,回车以后会自动扩展区域,并提取不重复。
=UNIQUE(A1:A18)
除了可以针对一列,同时也可以针对多列,比如针对公司名称和软件提取不重复。
=UNIQUE(A1:B18)
7、不重复计数
UNIQUE可以提取不重复值,怎么进行不重复计数?
那太简单了,再嵌套个COUNTA统计个数就行。
=COUNTA(UNIQUE(B2:B18))
那如果是按公司名称、软件2个条件不重复计数呢?
同样简单,改下区域,再除以2就可以。
=COUNTA(UNIQUE(A2:B18))/2
8、用SORT函数对内容自动排序
对月份降序。
=SORT(F2:G4,1,-1)
语法说明:
=SORT(区域,对第几列排序,-1为降序1为升序)
比如现在要对金额升序。
=SORT(F2:G4,2,1)
9、凭证自动生成的最简单公式
以前小编分享过凭证自动生成的方法,不过实在太繁琐了,详见:凭证自动生成,太难了?
只需在一个单元格输入公式,就自动扩展,简单到没朋友。
=FILTER(C2:G11,B2:B11=D14)
语法说明:
=FILTER(返回区域,条件区域=条件)
10、找不到对应值,不用再嵌套IFERROR
正常情况下,用VLOOKUP或者LOOKUP查找的时候,找不到对应值会显示#N/A,一般情况下需要嵌套IFERROR。
而XLOOKUP即便是找不到对应值,也不需要嵌套其他函数。
=XLOOKUP(E2,A:A,B:B,"")
语法说明:
=XLOOKUP(查找值,查找区域,返回区域,错误值显示值)
11、将查找到的所有对应值去除重复,再合并在一个单元格
这个前阵子帮学员写了一个公式,套了又套,挺复杂的。现在有了新函数,那一切就不一样了。
=TEXTJOIN(",",1,UNIQUE(FILTER($A$2:$A$18,$B$2:$B$18=F2)))
这个就相当于将前面学的函数综合起来,FILTER就是将符合条件的筛选出来,再用UNIQUE去除重复值,最后用TEXTJOIN将内容合并起来。
12、标题顺序不一样的合并CHOOSECOLS
2个表的标题顺序不一样,现在想合并在一起,除了一列一列复制粘贴,还有什么更好的方法?
比如要将姓名合并过来。
=CHOOSECOLS(H2:L10,2)
语法:
返回区域第几列的内容。
=CHOOSECOLS(区域,第几列)神奇的地方还在后面,这个函数如果要返回多列也可以,比如返回第2、3、1列。
=CHOOSECOLS(H2:L10,2,3,1)
前面提到可以用MATCH判断内容分别在第几列。
=CHOOSECOLS(H2:L10,MATCH(A1:E1,H1:L1,0))
13、能实现透 视表各种统计的GROUPBY
统计每个项目的金额行区域A1:A72,值区域D1:D72,汇总方式SUM(也就是求和),3代表包含标题。
=GROUPBY(A1:A72,D1:D72,SUM,3)
汇总方式有非常多,最大值MAX,最小值MIN,平均值AVERAGE等等,现在以其中一个演示。
=GROUPBY(A1:A72,D1:D72,AVERAGE,3)
统计每个项目对应负责人的金额
行区域是从左到右按顺序,因此可以写A1:B72。
=GROUPBY(A1:B72,D1:D72,SUM,3)
其他情况下,都需要结合HSATCK函数才行,比如求每个负责人对应项目的金额。
=GROUPBY(HSTACK(B1:B72,A1:A72),D1:D72,SUM,3)
其他传统的方式就不再说明,跟普通的透 视表差不多,可以互相取代。下面讲新函数优势的地方。
根据项目合并负责人(数据源已去重复)透 视表的强项是处理数据,而处理文本并不擅长。而新函数不管数据还是文本,都可以处理。
ARRAYTOTEXT的作用就是按分隔符号合并文本。
=GROUPBY(A1:A7,B1:B7,ARRAYTOTEXT,3)
如果数据源有重复值,直接处理超级麻烦,建议辅助列用UNIQUE函数去重复。
=UNIQUE(A1:B72)
再引用辅助列的区域。
=GROUPBY(F1:F7,G1:G7,ARRAYTOTEXT,3)
将多表合并后,汇总项目对应的金额合并多表以前都是借助PQ,再用透 视表统计。现在可以借助VSTACK合并,再用GROUPBY统计。假如原来是每个项目一张工作表。
使用公式:=GROUPBY(VSTACK(恩施市:华容区!A1:A72),VSTACK(恩施市:华容区!D1:D72),SUM,3)
这里再单独演示VSTACK的作用,就是将多表的数据合并在一个表。不过直接合并的时候,有一个小缺陷,会出现一大堆无用的0。
这种当然也可以处理掉,不过不是这篇文章讨论的内容,以后再说。=VSTACK(恩施市:华容区!A1:D72)
14、分表录入,总表自动更新
格式相同的分表。
多表合并的方法非常多,有VBA、PQ等,今天小编分享新函数VSTACK+FILTER。
VSTACK函数语法跟SUM函数几乎一样,懂得SUM就可以。
最原始的用法,就是分别引用每个分表的区域,再用逗号隔开。
=VSTACK('01.现金'!A2:E11,'02.银行'!A2:E12,'03.微信'!A2:E11,'04.支付宝'!A2:E10)
语法:
=VSTACK(区域1,区域2,区域3,区域4)使用最多的还是下面这种。
=VSTACK('01.现金:04.支付宝'!A2:E12)
语法:
=VSTACK('开始表格名称:结束表格名称'!区域)因为分表要每天记录新数据,可以将区域写大点,这样就可以动态合并。
不过美中不足的是,总表就会出现很多0。
=VSTACK('01.现金:04.支付宝'!A2:E120)
要去掉这些0,其实也不难,借助FILTER函数,判断E列不等于0即可。先来看辅助列方法。
=FILTER(A2:E999,E2:E999<>0)
语法:
=FILTER(返回区域,条件区域=条件)
当然,不用辅助列,一步到位也行,两个区域都套VSTACK函数。
这里有一个很容易出错的地方要特别注意,返回区域是A2:E120,条件区域是E2:E120,千万别写一样。
=FILTER(VSTACK('01.现金:04.支付宝'!A2:E120),VSTACK('01.现金:04.支付宝'!E2:E120)<>0)
假如在最后一个表输入一行新内容。
在总表就能看到,相当于自动合并,实现一劳永逸。
15.能实现透 视表各种统计的PIVOTBYPIVOTBY
PIVOTBY估计是参数最多的函数,共计11个参数,今天只讲前5个。这里多了一个列区域。
=PIVOTBY(行区域,列区域,值区域,汇总方式,是否包含标题)
统计每个项目的金额
行区域A1:A11,列区域不需要就用逗号占位,值区域D1:D11,汇总方式SUM(也就是求和),3代表包含标题。
=PIVOTBY(A1:A11,,D1:D11,SUM,3)
统计每个项目对应负责人的金额行区域是从左到右按顺序,因此可以写A1:B11。
=PIVOTBY(A1:B11,,D1:D11,SUM,3)
其实,还有一种效果,项目在行区域,负责人在列区域,金额在值区域。
=PIVOTBY(A1:A11,B1:B11,D1:D11,SUM,3)
这种带标题的效果感觉不太好,3去掉就是不带标题,看起来更简洁。
=PIVOTBY(A1:A11,B1:B11,D1:D11,SUM)
根据项目、年月合并负责人
将项目、年月用&合并到一起再处理最简单,ARRAYTOTEXT的作用就是按分隔符号合并文本。
=PIVOTBY(A1:A11&C1:C11,,B1:B11,ARRAYTOTEXT,3)
当然也可以将项目、年月分开变成2列,就需要嵌套HSTACK函数。
=PIVOTBY(HSTACK(A1:A11,C1:C11),,B1:B11,ARRAYTOTEXT,3)
还有一种就是年月放在列区域。
=PIVOTBY(A1:A11,C1:C11,B1:B11,ARRAYTOTEXT,3)
其实,这些行列总计、标题之类的都可以去掉,区域从第2行开始,同时设置后面几个参数实现。
=PIVOTBY(A2:A11,C2:C11,B2:B11,ARRAYTOTEXT,0,0,,0,,,0)