Posted in PHP onMay 07, 2011
我这么想的:
遍历一遍多维数组,将所有的键建立索引生成一个一维数组;
每次通过键名去查这个键的上级数组及数据
OK,代码如下
indexKey创建索引数组函数:
<?php /** * FILE_NAME : arr.php FILE_PATH : test/ * 在多维数组中根据键名快速查询其父键以及父键值 * * @copyright Copyright (c) 2006-2010 mail:levi@cgfeel.com * @author Levi * @package test.arr * @subpackage * @version 2011-04-29 */ header("Content-Type: text/html; charset=utf-8"); $arr = array ( 'china' => array ( 'name' => '中国', 'cite' => array ( 'beijing' => array ( 'name' => '北京', 'site' => array('chaoyang' => '朝阳区', 'xuanwu' => '宣武区') ), 'shanghai' => array ( 'name' => '上海', 'site' => array('jingan' => '静安区', 'huangpu' => '黄浦区') ) ) ) ); function printA($data) { echo '<pre>'; print_r($data); echo '</pre>'; } function indexKey($data, $parent = NULL) { $arr = array(); foreach ($data as $key => $value) { $arr[$key] = $parent; if (is_array($value)) { $arr += indexKey($value, $key); } } return (Array)$arr; } printA(indexKey($arr)); ?>
打印出数据如下
Array
(
[china] =>
[name] => china
[cite] => china
[beijing] => cite
[site] => beijing
[chaoyang] => site
[xuanwu] => site
[shanghai] => cite
[jingan] => site
[huangpu] => site
)
不过上面那样写存在一个问题,即:如果有同名键,会造成丢失,于是我写了这么一个类
只需要将数组传递给对象,对象提供两个接口
printArr 打印索引数组
search 查询键名的父数组键名
IndexKey创建查询索引查询类:
<?php /** * FILE_NAME : arr.php FILE_PATH : test/ * 在多维数组中根据键名快速查询其父键以及父键值 * * @copyright Copyright (c) 2006-2010 mail:levi@cgfeel.com * @author Levi * @package test.arr * @subpackage * @version 2011-04-29 */ header("Content-Type: text/html; charset=utf-8"); $arr = array ( 'china' => array ( 'name' => '中国', 'cite' => array ( 'beijing' => array ( 'name' => '北京', 'site' => array('chaoyang' => '朝阳区', 'xuanwu' => '宣武区') ), 'shanghai' => array ( 'name' => '上海', 'site' => array('jingan' => '静安区', 'huangpu' => '黄浦区') ) ) ) ); function printA($data) { echo '<pre>'; print_r($data); echo '</pre>'; } function printP(IndexKey $obj, $key) { $parent = $obj->search($key); if ($parent) { echo '"'.$key.'" Parent Key is: '; if (!is_array($parent)) { echo $parent."<br />\n"; } else printA($parent); } else echo 'NO Parent OR No Search of "'.$key.'"!'."<br /><br />\n"; } class IndexKey { private $_arr = array(); public function __construct($data) { $this->_createIndex($data); } public function printArr() { return (Array)$this->_arr; } public function search($key) { return isset($this->_arr[$key]) ? $this->_arr[$key] : NULL; } private function _createIndex($data, $parent = NULL) { foreach ($data as $key => $value) { $this->_checkIndex($key, $parent); if (is_array($value)) { $this->_createIndex($value, $key); } } } private function _checkIndex($key, $parent) { $index = isset($this->_arr[$key]) ? $this->_arr[$key] : NULL; if ($index) { if (is_array($index)) { array_push($this->_arr[$key], $parent); } else $this->_arr[$key] = array($index, $parent); } else $this->_arr[$key] = $parent; } } $index = (Object)new IndexKey($arr); printA($index->printArr()); printP($index, 'beijing'); printP($index, 'name'); printP($index, 'china'); ?>
最后只差一个数据的输出了,于是我将这个类修改了下
提供了三个对外的方法
printArr 打印索引数组
search 查询键名的父数组键名
parentValue 查询父键值
/** * FILE_NAME : arr.php FILE_PATH : test/ * 在多维数组中根据键名快速查询其父键以及父键值 * * @copyright Copyright (c) 2006-2010 mail:levi@cgfeel.com * @author Levi * @package test.arr * @subpackage * @version 2011-04-29 */ header("Content-Type: text/html; charset=utf-8"); $arr = array ( 'china' => array ( 'name' => '中国', 'cite' => array ( 'beijing' => array ( 'name' => '北京', 'site' => array('chaoyang' => '朝阳区', 'xuanwu' => '宣武区') ), 'shanghai' => array ( 'name' => '上海', 'site' => array('jingan' => '静安区', 'huangpu' => '黄浦区') ) ) ) ); function printA($data) { echo '<pre>'; print_r($data); echo '</pre>'; } function printP2(IndexArr $obj, $key) { $parent = $obj->search($key); if (!is_array($parent)) { if ($parent) { echo '"'.$key.'" Parent Key is: '.$parent."<br />\n"; } else echo 'NO Parent OR No Search of "'.$key.'"!'."<br />\n";; echo '"'.$key.'" Parent "'.$parent.'" Value is: '; printA($obj->parentValue($key)); } else printA($parent); } class IndexArr { private $_arr = array(); public function __construct($data) { $this->_createIndex($data); } public function printArr() { return (Array)$this->_arr; } public function search($key) { return isset($this->_arr[$key]) ? $this->_arr[$key]['parent'] : NULL; } public function parentValue($key) { return isset($this->_arr[$key]) ? $this->_arr[$key]['data'] : NULL; } private function _createIndex($data, $parent = NULL) { foreach ($data as $key => $value) { $this->_checkIndex($key, $parent, $data); if (is_array($value)) { $this->_createIndex($value, $key); } } } private function _checkIndex($key, $parent, $data) { $data = $parent && isset($data[$parent]) ? $data[$parent] : $data; !isset($this->_arr[$key]) && $this->_arr[$key] = array('data' => $data, 'parent' => ''); $index = &$this->_arr[$key]['parent']; if (!empty($index)) { if (is_array($index)) { array_push($index, $parent); } else $index = array($index, $parent); } else $index = $parent; } } $index2 = (Object)new IndexArr($arr); printA($index2->printArr()); printP2($index2, 'beijing'); printP2($index2, 'name'); printP2($index2, 'china'); ?>
源文件代码:php_arr.rar
php在多维数组中根据键名快速查询其父键以及父键值的代码
声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@