(PHP 4, PHP 5, PHP 7, PHP 8)
extract — 從數(shù)組中將變量導(dǎo)入到當(dāng)前的符號(hào)表
&$array
, int $flags
= EXTR_OVERWRITE
, string $prefix
= ""): int本函數(shù)用來將變量從數(shù)組中導(dǎo)入到當(dāng)前的符號(hào)表中。
檢查每個(gè)鍵名看是否可以作為一個(gè)合法的變量名,同時(shí)也檢查和符號(hào)表中已有的變量名的沖突。
array
一個(gè)關(guān)聯(lián)數(shù)組。此函數(shù)會(huì)將鍵名當(dāng)作變量名,值作為變量的值。
對(duì)每個(gè)鍵/值對(duì)都會(huì)在當(dāng)前的符號(hào)表中建立變量,并受到
flags
和 prefix
參數(shù)的影響。
必須使用關(guān)聯(lián)數(shù)組,數(shù)字索引的數(shù)組將不會(huì)產(chǎn)生結(jié)果,除非用了
EXTR_PREFIX_ALL
或者 EXTR_PREFIX_INVALID
。
flags
對(duì)待非法/數(shù)字和沖突的鍵名的方法將根據(jù)取出標(biāo)記
flags
參數(shù)決定。可以是以下值之一:
EXTR_OVERWRITE
EXTR_SKIP
EXTR_PREFIX_SAME
prefix
。
EXTR_PREFIX_ALL
prefix
。
EXTR_PREFIX_INVALID
prefix
。
EXTR_IF_EXISTS
EXTR_PREFIX_IF_EXISTS
EXTR_REFS
array
參數(shù)的值。可以單獨(dú)使用這個(gè)標(biāo)志或者在
flags
中用 OR 與其它任何標(biāo)志結(jié)合使用。
如果沒有指定 flags
,則被假定為 EXTR_OVERWRITE
。
prefix
注意 prefix
僅在
flags
的值是
EXTR_PREFIX_SAME
,EXTR_PREFIX_ALL
,EXTR_PREFIX_INVALID
或 EXTR_PREFIX_IF_EXISTS
時(shí)需要。
如果附加了前綴后的結(jié)果不是合法的變量名,將不會(huì)導(dǎo)入到符號(hào)表中。前綴和數(shù)組鍵名之間會(huì)自動(dòng)加上一個(gè)下劃線。
返回成功導(dǎo)入到符號(hào)表中的變量數(shù)目。
示例 #1 extract() 例子
extract() 的一種可能用法是將 wddx_deserialize() 返回的結(jié)合數(shù)組中的內(nèi)容導(dǎo)入到符號(hào)表變量中去。
<?php
/* 假定 $var_array 是 wddx_deserialize 返回的數(shù)組*/
$size = "large";
$var_array = array("color" => "blue",
"size" => "medium",
"shape" => "sphere");
extract($var_array, EXTR_PREFIX_SAME, "wddx");
echo "$color, $size, $shape, $wddx_size\n";
?>
以上例程會(huì)輸出:
blue, large, sphere, medium
$size 沒有被覆蓋,因?yàn)橹付? EXTR_PREFIX_SAME
,這使得 $wddx_size
被建立。如果指定了 EXTR_SKIP
,則 $wddx_size
也不會(huì)被建立。EXTR_OVERWRITE
將使 $size
的值為“medium”,EXTR_PREFIX_ALL
將建立新變量
$wddx_color,$wddx_size 和
$wddx_shape。
不要對(duì)不能信任的數(shù)據(jù)使用
extract(),例如用戶的輸入($_GET, $_FILES...)。
如果這樣做,要確保使用不會(huì)覆蓋的
flags
值,例如
EXTR_SKIP
,并且要留意應(yīng)該按照
variables_order
在 php.ini 里
定義的順序來提取。