多次元配列のキー名に基づいて親キーと親キーの値を迅速にクエリするための PHP コード_PHP チュートリアル
Jul 21, 2016 pm 03:29 PM
php
コード
存在する
多次元
速い
私
配列
お問い合わせ
父
の
トラバース
鍵
キー値
キー名
私が思うこと:
多次元配列を一度走査し、すべてのキーにインデックスを付けて 1 次元配列を生成します
毎回キー名を通じてこのキーの上位配列とデータを確認します
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 = 配列
(
'中国' => 配列
(
'名前' => '中国',
'cite' => 配列
(
'北京' = > 配列
(
'名前' = > '北京',
'サイト' => array('朝陽' => '朝陽区', '玄武' => '玄武区')
),
'上海' => array
(
'name' => '上海',
'サイト' => array('jingan' => '静安区', '黄浦' => '黄浦区')
)
)
)
) ;
function printA($data)
echo '<pre>'
print_r($data)';
関数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)); >
次のようにデータを出力します
配列
(
[中国] =>
[名前] => 中国
[引用] => 中国
[サイト] => 北京
[朝陽] => サイト
[玄武] => サイト
[上海] => サイト
[黄埔] => サイト
)
ただし、上記の書き方には問題があります。つまり、同じ名前のキーがあるとLostが発生するので、そのようなクラスを書きました
配列をオブジェクトに渡すだけでよく、オブジェクトはインデックス配列を出力するための2つのインターフェイスを提供します
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
(
'中国' => array
(
'name' => '中国',
'cite' => 配列
(
'北京' => 配列
(
'名前' => '北京 ',
'サイト' => 配列('朝陽' => '朝陽地区', '玄武' => '玄武区')
),
'上海' => array
(
'name' => '上海',
'site' => array('jingan' => '静安区', '黄浦区')
)
)
);
function printA ($data)
echo '<pre>'; ($data);
echo '</pre>';
}
function printP(IndexKey $obj, $key)
{
$parent = $obj->search($key); )
{
echo '"'.$key.'" 親キーは: ';
if (!is_array($parent))
{
echo $parent."<br />n"; else printA($parent);
}
else echo '親がいない OR '.$key.' の検索がありません!'."< br /><br />n"; IndexKey
{
private $_arr = array();
public 関数 __construct($data)
{
$this->_createIndex($data)
}
public 関数 printArr()
{
return (Array)$ this->_arr;
}
public function search($key)
return isset($this->_arr[$key]) : NULL;プライベート関数 _createIndex($data, $parent = NULL)
{
foreach ($data as $key => $value)
{
$this ->_checkIndex($key, $parent)
if (is_array( $value))
{
$this->_createIndex($value, $key);
}
}
}
プライベート関数 _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, '中国')>
最終的に、データ出力は 1 つだけ残ったので、このクラスを変更しました
3 つの外部メソッドを提供しました
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
(
'中国' => 配列
(
'名前' => '中国',
'cite' => 配列
(
'北京' => 配列
(
'名前' => '北京',
' サイト' => array('朝陽' => '朝陽区', '玄武' => '玄武区')
),
'上海' => ' => ' 上海',
' サイト' => array('jingan' => '静安区', '黄浦' => '黄浦区')
)
)
)
);
関数 printA($data)
{
$parent = $obj- >search($key);
if (!is_array($parent))
{
if ($parent)
{
echo '"'.$key.'" 親キーは: '.$parent."<br />n";
}
else echo '親がいない、または ".$key.'" の検索がありません!'."<br />n";; echo '"'.$key .'" 親 "'.$parent.'" 値は: ';
printA($obj->parentValue($key));
else printA($parent);
クラス IndexArr
{
プライベート $_arr = array();
パブリック関数 __construct($data)
{
$this->_createIndex($data)
}
パブリック関数 printArr()
return (配列)$this-> _arr;
}
public function search($key)
return isset($this->_arr[$key]['parent) '] : NULL;
パブリック関数parentValue($key)
{
return isset($this->_arr[$key]['data']) : NULL ;
}
プライベート関数 _createIndex ($data, $parent = NULL)
{
foreach ($data as $key => $value)
{
$this->_checkIndex($key, $parent, $data );
if (is_array( $value))
{
$this->_createIndex($value, $key)
}
}
}
プライベート関数 _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']; empty($index))
{
if (is_array($index))
{
array_push($index, $parent)
}
else $index = array($index, $parent);インデックス = $parent;
}
$index2 = (オブジェクト)new IndexArr($arr);
printP2($index2, '北京'); $index2, 'name') ;
printP2($index2, 'china');
ソースファイルコード: php_arr
http://www.bkjia.com/PHPjc/323369.html
www.bkjia.com
true
http://www.bkjia.com/PHPjc/323369.html
技術記事
私が考えること: 多次元配列を 1 回走査し、すべてのキーにインデックスを付けて 1 次元配列を生成します。毎回、キー名を通じてこのキーの上位配列とデータを確認します。コードは次のとおりです。
* @subpackage
* @version 2011-04-29
*/
header("Content-Type: text/html; charset=utf-8");
$arr = array
(
'中国' => array
(
'name' => '中国',
'cite' => 配列
(
'北京' => 配列
(
'名前' => '北京 ',
'サイト' => 配列('朝陽' => '朝陽地区', '玄武' => '玄武区')
),
'上海' => array
(
'name' => '上海',
'site' => array('jingan' => '静安区', '黄浦区')
)
)
);
function printA ($data)
echo '<pre>'; ($data);
echo '</pre>';
}
function printP(IndexKey $obj, $key)
{
$parent = $obj->search($key); )
{
echo '"'.$key.'" 親キーは: ';
if (!is_array($parent))
{
echo $parent."<br />n"; else printA($parent);
}
else echo '親がいない OR '.$key.' の検索がありません!'."< br /><br />n"; IndexKey
{
private $_arr = array();
public 関数 __construct($data)
{
$this->_createIndex($data)
}
public 関数 printArr()
{
return (Array)$ this->_arr;
}
public function search($key)
return isset($this->_arr[$key]) : NULL;プライベート関数 _createIndex($data, $parent = NULL)
{
foreach ($data as $key => $value)
{
$this ->_checkIndex($key, $parent)
if (is_array( $value))
{
$this->_createIndex($value, $key);
}
}
}
プライベート関数 _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, '中国')>
最終的に、データ出力は 1 つだけ残ったので、このクラスを変更しました
3 つの外部メソッドを提供しました
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
(
'中国' => 配列
(
'名前' => '中国',
'cite' => 配列
(
'北京' => 配列
(
'名前' => '北京',
' サイト' => array('朝陽' => '朝陽区', '玄武' => '玄武区')
),
'上海' => ' => ' 上海',
' サイト' => array('jingan' => '静安区', '黄浦' => '黄浦区')
)
)
)
);
関数 printA($data)
{
$parent = $obj- >search($key);
if (!is_array($parent))
{
if ($parent)
{
echo '"'.$key.'" 親キーは: '.$parent."<br />n";
}
else echo '親がいない、または ".$key.'" の検索がありません!'."<br />n";; echo '"'.$key .'" 親 "'.$parent.'" 値は: ';
printA($obj->parentValue($key));
else printA($parent);
クラス IndexArr
{
プライベート $_arr = array();
パブリック関数 __construct($data)
{
$this->_createIndex($data)
}
パブリック関数 printArr()
return (配列)$this-> _arr;
}
public function search($key)
return isset($this->_arr[$key]['parent) '] : NULL;
パブリック関数parentValue($key)
{
return isset($this->_arr[$key]['data']) : NULL ;
}
プライベート関数 _createIndex ($data, $parent = NULL)
{
foreach ($data as $key => $value)
{
$this->_checkIndex($key, $parent, $data );
if (is_array( $value))
{
$this->_createIndex($value, $key)
}
}
}
プライベート関数 _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']; empty($index))
{
if (is_array($index))
{
array_push($index, $parent)
}
else $index = array($index, $parent);インデックス = $parent;
}
$index2 = (オブジェクト)new IndexArr($arr);
printP2($index2, '北京'); $index2, 'name') ;
printP2($index2, 'china');
ソースファイルコード: php_arr
http://www.bkjia.com/PHPjc/323369.html
www.bkjia.com
true
http://www.bkjia.com/PHPjc/323369.html
技術記事
私が考えること: 多次元配列を 1 回走査し、すべてのキーにインデックスを付けて 1 次元配列を生成します。毎回、キー名を通じてこのキーの上位配列とデータを確認します。コードは次のとおりです。
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

人気の記事
スプリットフィクションを打ち負かすのにどれくらい時間がかかりますか?
3週間前
By DDD
レポ:チームメイトを復活させる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
ハローキティアイランドアドベンチャー:巨大な種を手に入れる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.説明されたエネルギー結晶と彼らが何をするか(黄色のクリスタル)
1週間前
By 尊渡假赌尊渡假赌尊渡假赌

人気の記事
スプリットフィクションを打ち負かすのにどれくらい時間がかかりますか?
3週間前
By DDD
レポ:チームメイトを復活させる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
ハローキティアイランドアドベンチャー:巨大な種を手に入れる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.説明されたエネルギー結晶と彼らが何をするか(黄色のクリスタル)
1週間前
By 尊渡假赌尊渡假赌尊渡假赌

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック
Gmailメールのログイン入り口はどこですか?
7142
9


Java チュートリアル
1534
14


Laravel チュートリアル
1257
25


PHP チュートリアル
1205
29


CakePHP チュートリアル
1155
46



Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法
