当前位置: 网学 > 编程文档 > PHP > 正文

PHP下对数组进行排序的函数

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 13/06/21
排后生成的结果进行比较,就能很容易明白两者的不同了。
复制代码 代码如下:
Array ([US] => United States
[ES] => Spain
[IN] => India
[DE] => Germany
)

自然语言排序
PHP有一个非常独特的排序方式,这种方式使用认知而不是使用计算规则。这种特性称为自然语言排序,当创建模糊逻辑应用软件的时候这种排序方式非常有用。下面大家可以来看看它的一个简单例子,如Listing G所示:
Listing G
复制代码 代码如下:
<?php $data = array(“book-1″, “book-10″, “book-100″, “book-5″); sort($data);print_r($data);
natsort($data); print_r($data);?>

它的输出结果如下:
复制代码 代码如下:
Array ([0] => book-1
=> book-10
=> book-100
=> book-5
)
Array
(
[0] => book-1
=> book-5
=> book-10
=> book-100
)

它们的不同已经很清楚了:第二个排序结果更直观,更“人性化”,然而第一个则更符合算法规则,更具“计算机”特点。
自然语言能进行倒排吗?答案是肯定的!只要对natsort()的结果使用array_reverse()函数就可以了,Listing H就是一个简单例子:
Listing H
复制代码 代码如下:
<?php $data = array(“book-1″, “book-10″, “book-100″, “book-5″);natsort($data); print_r(array_reverse($data));
?>

下面是它的输出结果:
复制代码 代码如下:
Array ([0] => book-100
=> book-10
=> book-5
=> book-1
)

根据用户自定义的规则排序
PHP也能让你定义自己的排序算法,你可以通过创建你自己的比较函数,并把它传递给usort()函数。如果第一个参数比第二个参数“小”的话,比较函数必须返回一个比0小的数,如果第一参数比第二个参数“大”的话,比较函数应该返回一个比0大的数。
Listing I就是这样的一个例子,在这个例子中根据它们的长度对数组元素进行排序,最短的项放在最前面:
Listing I
复制代码 代码如下:
<?php $data = array(“joe@host.com”, “john.doe@gh.co.uk”, “asmithsonian@us.info”, “jay@zoo.tw”);usort($data, ‘sortByLen'');
print_r($data); function sortByLen($a, $b) {
if (strlen($a) == strlen($b)) {
return 0;
} else {
return (strlen($a) > strlen($b)) ? 1 : -1;
}
}
?>

这样,就创建了我们自己的比较函数,这个函数使用strlen()函数比较每一个字符串的个数,然后分别返回1,0或-1.这个返回值是决定元素排列的基础。下面是它的输出结果:
复制代码 代码如下:
Array ([0] => jay@zoo.tw
=> joe@host.com
=> john.doe@gh.co.uk
=> asmithsonian@us.info
)

自然语言排序
PHP有一个非常独特的排序方式,这种方式使用认知而不是使用计算规则。这种特性称为自然语言排序,当创建模糊逻辑应用软件的时候这种排序方式非常有用。下面大家可以来看看它的一个简单例子,如Listing G所示:
Listing G
复制代码 代码如下:
<?php $data = array(“book-1″, “book-10″, “book-100″, “book-5″); sort($data);print_r($data);
natsort($data); print_r($data);?>

它的输出结果如下:
复制代码 代码如下:
Array ([0] => book-1
=> book-10
=> book-100
=> book-5
)
Array
(
[0] => book-1
=> book-5
=> book-10
=> book-100
)

它们的不同已经很清楚了:第二个排序结果更直观,更“人性化”,然而第一个则更符合算法规则,更具“计算机”特点。
自然语言能进行倒排吗?答案是肯定的!只要对natsort()的结果使用array_reverse()函数就可以了,Listing H就是一个简单例子:
Listing H
复制代码 代码如下:
<?php $data = a

网学推荐

免费论文

原创论文

浏览:
设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
湘ICP备09003080号