php_关联数组,PHP中关联数组的用法详解
1、添加数组元素
PHP是一种弱类型语言,这意味着你不需要显示声明一个
php中关联数据用法与一些关联数组的一些小技巧,包括添加,删除,编辑,遍历,交换键和值,排序,查询等等关联数组的一些实例. 1、添加数组元素 PHP是一种弱类型语言,这意味着你不需要显示声明一个数组及其大小,相反,你可以同时声明并填充数组,代码如下: $capitals=array( 'Alabama'=>'Montgomery', 'Alaska'=>'Juneau', 'Arizona'=>'Phoenix' ); 额外的数组元素可以象下面这样追加: $capitals['Arkansas'] = 'Little Rock'; 如果你正在处理数字索引数组,你可能想使用显示命名的函数前置和追加元素,如array_push()和array_unshift()函数,但这些函数不能操作关联数组. 2、删除数组元素 如果要从数组中删除一个元素,请使用unset()函数,代码如下: unset($capitals['California']); 使用数字索引数组时,删除数组元素的办法更多,更灵活,可以使用array_shift()和array_pop()函数分别从数组的开头和末尾删除一个元素. 3、交换键和值 假设你想创建一个名叫$states的新数组,使用州府作为索引,使用州名作为关联值,使用array_flip()函数很容易完成这个任务,代码如下: $capitals=array( 'Alabama'=>'Montgomery', 'Alaska'=>'Juneau', 'Arizona'=>'Phoenix' ); $states=array_flip($capitals); //$states=array( //'Montgomery'=>string'Alabama', //'Juneau'=>string'Alaska', //'Phoenix'=>string'Arizona' //); 4、合并数组 假设前面的数组由一个基于Web的“FlashCard”服务使用,你想提供一种方法测试学生对美国各州首府的掌握情况,你可以使用array_merge()函数合并包含州和首府的数组,代码如下: $stateCapitals=array( 'Alabama'=>'Montgomery', 'Alaska'=>'Juneau', 'Arizona'=>'Phoenix' ); $countryCapitals=array( 'Australia'=>'Canberra', 'Austria'=>'Vienna', 'Algeria'=>'Algiers' ); $capitals=array_merge($stateCapitals,$countryCapitals); 5、编辑数组值 假设在数组中的数据包含大小写错误,在插入到数据库之前,你想纠正这些错误,你可以使用array_map()函数给每个数组元素应用一个回调,代码如下: functioncapitalize($element) { $element=strtolower($element); returnucwords($element); } $capitals=array( 'Alabama'=>'montGoMEry', 'Alaska'=>'Juneau', 'Arizona'=>'phoeniX' ); $capitals=array_map("capitalize",$capitals); 6、按键对数组排序 FlashCard程序常常使用各种排序,如按字母顺序排序,你可以使用ksort()函数按键对关联数组进行排序,代码如下: $capitals=array( 'Arizona'=>'Phoenix', 'Alaska'=>'Juneau', 'Alabama'=>'Montgomery' ); ksort($capitals); 因为数组是通过参数传递给ksort()函数的,意味着你不再需要将排序结果分配给另一个变量. 7、随机数组排序 在FlashCard程序中还涉及到另一种随机排序技术,这时你要使用shuffle()函数实现数组项目的随机排序,代码如下: $capitals=array( 'Arizona'=>'Phoenix', 'Alaska'=>'Juneau', 'Alabama'=>'Montgomery' ); shuffle($capitals); 如果不需要打乱数组顺序,你只是想随机选择一个值,那么使用array_rand()函数即可. 8、确定键和值是否存在 你可以使用in_array()函数确定一个数组元素是否存在,代码如下: $capitals=array( 'Arizona'=>'Phoenix', 'Alaska'=>'Juneau', 'Alabama'=>'Montgomery' ); if(in_array("Juneau",$capitals)) { echo"Exists!"; }else{ echo"Doesnotexist!"; } 很少有人知道这个函数也可以确定一个数组键是否存在,在这一点上,它和array_key_exists()函数的功能一样,代码如下: $capitals=array( 'Arizona'=>'Phoenix', 'Alaska'=>'Juneau', 'Alabama'=>'Montgomery' ); if(array_key_exists("Alaska",$capitals)) { echo"Keyexists!"; }else{ echo"Keydoesnotexist!"; } 9、搜索数组 你可能想搜索数组资源,这样用户就可以方便地用一个特定的州府检索关联的州,可以通过array_search()函数实现数组搜索,代码如下: $capitals=array( 'Arizona'=>'Phoenix', 'Alaska'=>'Juneau', 'Alabama'=>'Montgomery' ); $state=array_search('Juneau',$capitals); //$state='Alaska' 10、标准PHP库 标准PHP库(Standard PHP Library,SPL)为开发人员提供了许多数据结构,迭代器,接口,异常和其它以前PHP语言没有的功能,使用这些功能可以通过面向对象的语法遍历数组,代码如下: $capitals=array( 'Arizona'=>'Phoenix', 'Alaska'=>'Juneau', 'Alabama'=>'Montgomery' ); $arrayObject=newArrayObject($capitals); foreach($arrayObjectas$state=>$capital) { printf("Thecapitalof%sis%s ",$state,$capital); } //ThecapitalofArizonaisPhoenix //ThecapitalofAlaskaisJuneau //ThecapitalofAlabamaisMontgomery 遍历关联数组的三种方法: foreach,代码如下: $sports=array( 'football'=>'good', 'swimming'=>'verywell', 'running'=>'notgood' ); foreach($sportsas$key=>$value){ echo$key.":".$value." "; } /* 程序运行结果: football:good swimming:verywell running:notgood */ each,代码如下: $sports=array( 'football'=>'good', 'swimming'=>'verywell', 'running'=>'notgood' ); while($elem=each($sports)){ echo$elem['key'].":".$elem['value']." "; } /* 程序运行结果: football:good swimming:verywell running:notgood */ list & each,代码如下: $sports=array( 'football'=>'good', 'swimming'=>'verywell', 'running'=>'notgood' ); while(list($key,$value)=each($sports)){ echo$key.":".$value." "; } /* 程序运行结果: football:good swimming:verywell running:notgood */ 哈希表== Hash Table 有一份用户名列表,存储了 10000 个用户名,没有重复项; 还有一份黑名单列表,存储了 2000 个用户名,格式与用户名列表相同; 现在需要从用户名列表中删除处在黑名单里的用户名,要求用尽量快的时间处理. 这个问题是一个小规模的处理量,如果实际一点,2 个表都可能很大,比如有 2 亿条记录. 我最开始想到的方法,就是做一个嵌套的循环,设用户名表有 M 条记录,黑名单列表有 N 条记录,那么,循环的次数是 M * N 次. PHP 版代码: foreach($arrayMas$keyM=>$nameM){ foreach($arrayNas$nameN){ if($nameM==$nameN){ //本行执行了M*N次! unset($arrayM[$keyM]); } } } return$arrayM; 另一种方式,利用数组索引. PHP 是一种弱类型的语言,不像 C 语言那样有严格的变量类型限制,C 语言的数组,每一个元素的类型必须一致,而且索引都是从 0 开始. PHP 的数组,可以用字符串作为索引,也称为关联数组. 数组索引,有一个天然的限制就是不会重复,而且访问的时候不需要查找,可以直接定位. 还是刚才的那个问题,我们采用另一种办法,把黑名单列表的用户名组织到一个数组里,数组的索引就是用户名,然后,遍历用户列表的时候,只需直接用 isset 查询那个用户名是否存在即可,代码如下: $arrayHash=array(); foreach($arrayNas$nameN){ //本行执行了N次。 $arrayHash[$nameN]=1; } foreach($arrayMas$keyM=>$nameM){ if(isset($arrayHash[$nameM])){ //本行执行了M次! unset($arrayM[$keyM]); } } return$arrayM; 可以看到,优化过的代码,循环次数是 M + N 次. 假如 M 和 N 都是 10000,优化前,循环了 1 亿次,优化后,只循环了 20000 次,差了 5000 倍,如果第二个程序耗时 1 秒,则第一个程序需要将近一个半小时. (编辑:威海站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |