- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
在Excel中利用数据的排序功能可以很轻松地进行排序
在Excel中利用数据的排序功能可以很轻松地进行排序,但这种排序会破坏原有的数据清单。笔者经过摸索,发现了两种可以利用公式自动排序且不破坏原始数据清单的方法。
一、利用数组公式
数组公式可以同时进行多重计算并返回一种或多种结果。数组公式对两组或多组被称为数组参数的数值进行运算。数组公式的创建方法很简单,在单元格中输入公式后按 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值。
两种方法各有优劣,数组公式法较简单,但不太好理解,而普通公式法则正相反,容易理解但操作较繁琐。
您可能关注的文档
最近下载
- 《心理健康讲座》ppt课件(图文).pptx
- 初中英语话剧7-8个人物的剧本.doc VIP
- 鲁教版五四制八年级上册生物 第七单元 第一章 动物的主要类群 练习题(无答案).doc VIP
- [人教版小学五年级上册美术教案.doc VIP
- 《中华人民共和国放射性污染防治法》知识培训.pptx VIP
- 二年级上册劳动技术教案(详).docx VIP
- 第2课 使用数字设备 教案 义务教育人教版信息科技三年级全一册.docx VIP
- DLT5161表格大全(电气装置安装工程质量检验和评定规程).pdf VIP
- 初中数学综合实践活动课教学策略研究.pptx VIP
- 六年级语文上册第二单元教材分析+说课.pptx VIP
文档评论(0)