好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

PHP中关联数组的用法详解 - php数组

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()函数给每个数组元素应用一个回调,代码如下:

function  capitalize( $element )    {       $element  =  strtolower ( $element );       return  ucwords( $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   "Does not exist!" ;    } 

很少有人知道这个函数也可以确定一个数组键是否存在,在这一点上,它和array_key_exists()函数的功能一样,代码如下:

$capitals  =  array (       'Arizona'  =>  'Phoenix' ,       'Alaska'   =>  'Juneau' ,       'Alabama'  =>  'Montgomery'     );    if  ( array_key_exists ( "Alaska" ,  $capitals ))    {       echo   "Key exists!" ;    }  else  {       echo   "Key does not exist!" ;    } 

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  =  new  ArrayObject( $capitals );    foreach  ( $arrayObject   as   $state  =>  $capital )    {      printf( "The capital of %s is %s<br />" ,  $state ,  $capital );    }    // The capital of Arizona is Phoenix     // The capital of Alaska is Juneau     // The capital of Alabama is Montgomery  

遍历关联数组的三种方法:

foreach,代码如下:

<?php  $sports  =  array (       'football'  =>  'good' ,       'swimming'  =>  'very well' ,       'running'   =>  'not good'    );    foreach  ( $sports   as   $key  =>  $value ) {       echo   $key . ": " . $value . "<br />" ;  }  ?>  /*   程序运行结果:   football: good   swimming: very well    running: not good   */  

each,代码如下:

<?php  $sports  =  array (       'football'  =>  'good' ,       'swimming'  =>  'very well' ,       'running'   =>  'not good'    );    while  ( $elem  = each( $sports )) {       echo   $elem [ 'key' ]. ": " . $elem [ 'value' ]. "<br />" ;  }  ?>  /*   程序运行结果:   football: good   swimming: very well   running: not good   */  

list & each,代码如下:

<?php  $sports  =  array (       'football'  =>  'good' ,       'swimming'  =>  'very well' ,       'running'   =>  'not good'    );    while  (list( $key ,  $value ) = each( $sports )) {       echo   $key . ": " . $value . "<br />" ;  }  ?>  /*   程序运行结果:   football: good   swimming: very well   running: not good   */  

哈希表== Hash Table

有一份用户名列表,存储了 10000 个用户名,没有重复项;

还有一份黑名单列表,存储了 2000 个用户名,格式与用户名列表相同;

现在需要从用户名列表中删除处在黑名单里的用户名,要求用尽量快的时间处理.

这个问题是一个小规模的处理量,如果实际一点,2 个表都可能很大,比如有 2 亿条记录.

我最开始想到的方法,就是做一个嵌套的循环,设用户名表有 M 条记录,黑名单列表有 N 条记录,那么,循环的次数是 M * N 次.

PHP 版代码:

<?php  foreach ( $arrayM   as   $keyM  =>  $nameM ) {      foreach ( $arrayN   as   $nameN ) {      if  ( $nameM  ==  $nameN ) {      // 本行执行了 M * N 次!      unset( $arrayM [ $keyM ]);     }     }  }  return   $arrayM ;  ?> 

另一种方式,利用数组索引.

PHP 是一种弱类型的语言,不像 C 语言那样有严格的变量类型限制,C 语言的数组,每一个元素的类型必须一致,而且索引都是从 0 开始.

PHP 的数组,可以用字符串作为索引,也称为关联数组.

数组索引,有一个天然的限制就是不会重复,而且访问的时候不需要查找,可以直接定位.

还是刚才的那个问题,我们采用另一种办法,把黑名单列表的用户名组织到一个数组里,数组的索引就是用户名,然后,遍历用户列表的时候,只需直接用 isset 查询那个用户名是否存在即可,代码如下:

<?php  $arrayHash  =  array ();  foreach ( $arrayN   as   $nameN ) {      // 本行执行了 N 次。       $arrayHash [ $nameN ] = 1;  }  foreach ( $arrayM   as   $keyM  =>  $nameM ) {      if  (isset( $arrayHash [ $nameM ])) {      // 本行执行了 M 次!      unset( $arrayM [ $keyM ]);     }  }  return   $arrayM ;  ?> 

可以看到,优化过的代码,循环次数是 M + N 次.

假如 M 和 N 都是 10000,优化前,循环了 1 亿次,优化后,只循环了 20000 次,差了 5000 倍,如果第二个程序耗时 1 秒,则第一个程序需要将近一个半小时.

查看更多关于PHP中关联数组的用法详解 - php数组的详细内容...

  阅读:41次