六合开奖结果现场直播欢迎诸位!收藏本站注 册登 陆
常用三肖中特马:基础知识网络知识操作系统WPS网页制作数据库算法网页成功之路网络安全最新技术古典mid流行midmid背景下载中心
您现在的位置:首页 > 三肖中特马 > 文章页

excel不改变原数据利用公式自动排序

Admin | 2015-11-14 5:50:56 | ReadNums | 3615 | 标签 六合开奖结果现场直播 | 打印本页
     

  有两种可以利用公式自动排序且不改变原始的方法,下面将其分享如下:

  一、使用数组公式

  数组公式可以同时进行多重计算并返回一种或多种结果。数组公式对两组或多组被称为数组参数的数值进行运算。数组公式的创建方法很简单,在单元格中输入公式后按 CTRL+SHIFT+ENTER 组合键即可生成数组公式。我们以下图中的Excel表中为例,现在我们想根据工资多少进行排序。

  为了便于输入,用Salary来代替$F$2:$F$31这个范围区域,用Name来代替$B$2:$B$31。

  在单元格H2中输入=INDEX(Name,MATCH(LARGE(Salary+ROW(Salary),ROW()-1),Salary+ROW(Salary),0)),最后按CTRL+SHIFT+ENTER,自动在公式两端加上{ }成为数组公式。

  下面我们将公式的作用详细说明如下。

  ROW(参数)函数的作用是得到参数所代表的单元格或单元格区域的行号,如果在数组公式中输入这个公式就得到一个行号数组。

  ROW(Salary)记录的是行号的信息, Salary+ROW(Salary)就是再原来工资的数目上再加上行号,这样是为了防止有相同的工资数目出现,避免因相同的工资数而出现错误的排序。

  ROW()-1则是给出一个从1到24的序数数组,便于从大到小对工资进行排序。LARGE(Salary+ROW(Salary),ROW()-1)是在Salary+ROW(Salary)的范围内找出一个ROW()-1大的数X(暂时用X来代替其返回值)。

  MATCH函数是返回在指定方式下与指定数值匹配的数组中元素的相应位置。MATCH(X,Salary+ROW(Salary),0)的作用是在Salary范围内查找X并且返回其所在的行号M(暂时用M代替返回的行号M)。

  INDEX(Name,M)是在Name范围内返回第M个元素的内容。

  这样就完成了从大到小的排序。

  为了便于与原进行比较,可在I2中输入=INDEX(Name,MATCH(LARGE(Salary+ROW(Salary),ROW()-1),Salary+ROW(Salary),0)),然后再按组合键,这样就可以将工资数目从高至低排列出来。

  如果要从小到大排序则只需把LARGE()函数换成SMALL()函数即可。

  二、利用普通公式进行排序

  在K2单元格中输入公式=IF(B2=0,0,INT(CONCATENATE(INT(F2),200-ROW(B1)))),将该公式下拉到K31(下拉指将鼠标移动到公式所在单元格的右下角,当鼠标变成一个小十字符号的时候,按住鼠标左键向下拉动,则此列的单元格中会自动加上相应的公式,下同)。

  该公式的作用是将工资与所在的行号信息进行整合。

  公式中的ROW(B1)就是B1单元格所在的行号。

  CONCATENATE函数是一个整合函数,本处是把F列的和它所在行数整合为一个,这样在对它进行排序后就包含了它所在的行的信息。

  用200减去ROW(B1)是为了使CONCATENATE的第2个参数保持3位数,保证整合后的的位数一致(当然本处用100来减也可以)。

  INT函数是为了把原来的文本内容变为数字。

  在L2单元格中输入=LARGE(K:K,ROW(B1)),并下拉至L31,对K列的进行排序。

  在N2中输入=IF(L2=0,0,200-RIGHT(L2,3)),并下拉至N31。该公式取得的最初行数信息。RIGHT(L2,3)的返回值是L2单元格的后3位数,用200来减去此数就是该所在的行数。

  在M2单元格中输入=IF(N2=0,0,INDEX(Name,N2,)),再下拉至M31,即可完成排序。该公式是根据行号来取得所对应的Name值,其实在N列中就已经完成了排序。INDEX(Name,N2)就是根据N2单元格中所代表的行号来返回其在name区域中所代表的单元格的内容。使用IF()函数是一种安全策略,防止出现0值。


问题未解决:在线咨询

网友评论

(访客)
内容实用原创,讲得很好。
20xx年x月x日
(站长)
有问题请在线咨询。
20xx年x月x日