首頁 >後端開發 >php教程 >火炬之光有多少層 php簡單物件與陣列的轉換函數程式碼php多層陣列和物件的轉換

火炬之光有多少層 php簡單物件與陣列的轉換函數程式碼php多層陣列和物件的轉換

WBOY
WBOY原創
2016-07-29 08:45:121106瀏覽

複製程式碼 程式碼如下:


function arrayToObject($e){
if( gettype($e)!='array ' ) return;
foreach($e as $k=>$v){
if( gettype($v)=='array' || getType($v)=='object' )
$e[$k]=(object)arrayToObject($v);
}
return (object)$e;
}
function objectToArray($e){
$ee>function objectToArray($e){
$ee =(array)$e;
foreach($e as $k=>$v){
if( gettype($v)=='resource' ) return;
if( gettype($v )=='object' || gettype($v)=='array' )
$e[$k]=(array)objectToArray($v);
}
return $e;
}



上面的內容來自cnblogs jaiho
php多層數組和物件的轉換
多層數組和物件轉換的用途很簡單,便於處理WebService中多層數組和物件的轉換
簡單的(array)和(object)只能處理單層的數據,對於多層的數組和物件轉換則無能為力。
透過json_decode(json_encode($object)可以將物件一次轉換為數組,但是object中遇到非utf-8編碼的非ascii字元則會出現問題,例如gbk的中文,何況json_encode和decode的效能也值得疑慮。 objectToArray($d) {
if (is_object($d)) {

// Gets the properties of the given object // with get_object_vars function $d = get_object_vars($d); } if (is_array($d)) {

/*

* Return array converted to object
* Using __FUNCTION__ (Magic constant)
* for recursive call
*/
return array_map(__FUNCTION__, $d);
}
else {
// Return array
return $d;
}
}
return $d;
}
}
Tounction arrayarray. ($d) {
if (is_array($d)) {
/*
* Return array converted to object
* Using __FUNCTION__ (Magic constant)
* for recursive call
*/
return (object) array_map(__FUNCTION__, $d);
}
else {
// Return object
return $d;
}
}
}
// Useage:
// Create new stdClass Object
$init = new stdClass;
// Add some test data
$init->foo = "Test data";
$init->bar = new stdClass;
$init->bar->baaz = "Testing";
$init->bar->fooz = new stdClass;
$init->bar-> fooz->baz = "Testing again";
$init->foox = "Just test";
// Convert array to object and then object back to array
$array = objectToArray($in)ToArray($in) ;
$object = arrayToObject($array);
// Print objects and array
print_r($init);
echo "n";
print_r($array);
echo "n";
print_r($array); echo "n";
print_r($object);
?>



以上就介紹了火炬之光有多少層php簡單物件與陣列的轉換函數程式碼php多層陣列和物件的轉換,包括了火炬之光有多少層方面的內容,希望對PHP教程有興趣的朋友有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn