设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

123下一页
返回列表 发新帖
查看: 10397|回复: 22
打印 上一主题 下一主题

[其它] 行号跟着数据跑—excel之自动排序

[复制链接]

点击这里给我发消息

跳转到指定楼层
1#
发表于 2007-8-31 11:10:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
在Excel中利用数据的排序功能可以很轻松地进行排序,但这种排序会破坏原有的数据清单。笔者经过摸索,发现了两种可以利用公式自动排序且不破坏原始数据清单的方法。   一、利用数组公式  数组公式可以同时进行多重计算并返回一种或多种结果。数组公式对两组或多组被称为数组参数的数值进行运算。数组公式的创建方法很简单,在单元格中输入公式后按 CTRL+SHIFT+ENTER 组合键即可生成数组公式。我们以下图中的Excel表中数据为例,现在我们想根据工资多少进行排序。   为了便于输入,用Salary来代替$F$2F$31这个范围区域,用Name来代替$B$2B$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值。   两种方法各有优劣,数组公式法较简单,但不太好理解,而普通公式法则正相反,容易理解但操作较繁琐。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2007-9-14 09:25:58 | 只看该作者
谢谢!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
3#
发表于 2007-9-24 16:31:19 | 只看该作者
游客,如果您要查看本帖隐藏内容请回复

第一种方式仍然可能存在问题
比如表中F20 木嫆清工资为3265,F21苗人凤工资若为3264,
二人的工资数+行号后,恰好相等,则在排序后的数据中,出现二次木嫆清,而没有苗人凤
第二种方式正在研究中……
游客,如果您要查看本帖隐藏内容请回复

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
4#
发表于 2007-9-25 12:44:00 | 只看该作者
第一种方法,把公式改为:
=INDEX(Salary,MATCH(LARGE(Salary+0.001*ROW(Salary),ROW()-1),Salary+0.001*ROW(Salary),0))
问题解决。
想问一下搂主,代替$F$2F$31这个范围区域的salary在excel中是怎么定义的?

点击这里给我发消息

5#
 楼主| 发表于 2007-9-25 14:44:30 | 只看该作者
谢谢这网友的关注...代替$F$2F$31这个范围区域的salary在excel中是怎么定义的?你选定F2&F31这写列然后点:插入--名称--定义       将那里的名字定义salary或其他的都可以
6#
发表于 2007-12-9 03:02:25 | 只看该作者
我也要来学习学习!!
7#
发表于 2008-6-15 09:05:35 | 只看该作者
我也要来学习学习!!
8#
发表于 2008-6-15 09:08:29 | 只看该作者
我也要来学习学习!!
9#
发表于 2008-6-16 21:47:28 | 只看该作者
我也要来学习学习!!
10#
发表于 2008-7-8 21:55:33 | 只看该作者
看一下附檔 比較容易理解
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-29 16:00 , Processed in 0.108039 second(s), 35 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表