從陣列中將變數匯入到目前的符號表

extract

(PHP 4, PHP 5, PHP 7, PHP 8)

extract從陣列中將變數匯入到目前的符號表

說明

extract(array &$array, int $flags = EXTR_OVERWRITE, string $prefix = ""): int

本函式用來將變數從陣列中匯入到目前的符號表中。

檢查每個鍵名看是否可以作為一個合法的變數名,同時也檢查和符號表中已有的變數名的衝突。

警告

不要對不可信的數據使用 extract(),類似使用者輸入 (例如 $_GET$_FILES)。

參數

array

一個關聯陣列。此函式會將鍵名當作變數名,值作為變數的值。 對每個鍵/值對都會在目前的符號表中建立變數,並受到 flagsprefix 參數的影響。

必須使用關聯陣列,數字索引的陣列將不會產生結果,除非用了 EXTR_PREFIX_ALL 或者 EXTR_PREFIX_INVALID

flags

對待非法/數字和衝突的鍵名的方法將根據取出標記 flags 參數決定。可以是以下值之一:

EXTR_OVERWRITE
如果有衝突,覆蓋已有的變數。
EXTR_SKIP
如果有衝突,不覆蓋已有的變數。
EXTR_PREFIX_SAME
如果有衝突,在變數名前加上字首 prefix
EXTR_PREFIX_ALL
給所有變數名加上字首 prefix
EXTR_PREFIX_INVALID
僅在非法/數字的變數名前加上字首 prefix
EXTR_IF_EXISTS
僅在目前符號表中已有同名變數時,覆蓋它們的值。其它的都不處理。 舉個例子,以下情況非常有用:定義一些有效變數,然後從 $_REQUEST 中僅匯入這些已定義的變數。
EXTR_PREFIX_IF_EXISTS
僅在目前符號表中已有同名變數時,建立附加了字首的變數名,其它的都不處理。
EXTR_REFS
將變數作為引用提取。這有力地表明瞭匯入的變數仍然引用了 array 參數的值。可以單獨使用這個標誌或者在 flags 中用 OR 與其它任何標誌結合使用。

如果沒有指定 flags,則被假定為 EXTR_OVERWRITE

prefix

注意 prefix 僅在 flags 的值是 EXTR_PREFIX_SAMEEXTR_PREFIX_ALLEXTR_PREFIX_INVALIDEXTR_PREFIX_IF_EXISTS 時需要。 如果附加了字首后的結果不是合法的變數名,將不會匯入到符號表中。字首和陣列鍵名之間會自動加上一個下劃線。

返回值

返回成功匯入到符號表中的變數數目。

範例

示例 #1 extract() 例子

extract() 的一種可能用法是將 wddx_deserialize() 返回的結合陣列中的內容匯入到符號表變數中去。

<?php

/* 假定 $var_array 是 wddx_deserialize 返回的陣列*/

$size "large";
$var_array = array("color" => "blue",
                   
"size"  => "medium",
                   
"shape" => "sphere");
extract($var_arrayEXTR_PREFIX_SAME"wddx");

echo 
"$color$size$shape$wddx_size\n";

?>

以上例程會輸出:

blue, large, sphere, medium

$size 沒有被覆蓋,因為指定了 EXTR_PREFIX_SAME,這使得 $wddx_size 被建立。如果指定了 EXTR_SKIP,則 $wddx_size 也不會被建立。EXTR_OVERWRITE 將使 $size 的值為「medium」,EXTR_PREFIX_ALL 將建立新變數 $wddx_color$wddx_size$wddx_shape

註釋

警告

不要對不能信任的數據使用 extract(),例如使用者的輸入($_GET$_FILES...)。 如果這樣做,要確保使用不會覆蓋的 flags 值,例如 EXTR_SKIP,並且要留意應該按照 variables_orderphp.ini 里 定義的順序來提取。

參見

  • compact() - 建立一個陣列,包括變數名和它們的值
  • list() - 把陣列中的值賦給一組變數

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *