摘要:遍歷完成后返回一個(gè)新的數(shù)組你可以同時(shí)處理多個(gè)數(shù)組你好嗎原罪你好嗎原罪是的,遍歷的次數(shù)以最長的數(shù)組為準(zhǔn)。假如你處理的是二維數(shù)組,處理方式也是萬變不離其宗的。
在PHP的日常操作中,數(shù)組是最常出現(xiàn)的結(jié)構(gòu),而我們幾乎每天都在處理數(shù)組相關(guān)的內(nèi)容。那么問題來了,你一般怎么遍歷并處理數(shù)組。
1、foreach很熟悉吧,是不是你的最愛?
$arr = ["a", "b", "c"]; foreach ($arr as $key => $value) { $arr[$key] = $value . "_i"; } print_r($arr); // ["a_i", "b_i", "c_i"];2、array_map
使用匿名函數(shù)的方式,處理數(shù)組里的每個(gè)元素。遍歷完成后返回一個(gè)新的數(shù)組
$arr = ["a", "b", "c"]; $arr = array_map(function ($item) { return $item . "_i"; }, $arr); print_r($arr); // ["a_i", "b_i", "c_i"];
你可以同時(shí)處理多個(gè)數(shù)組
$arr_1 = ["a", "b", "c"]; $arr_2 = ["你", "好", "嗎", "原", "罪"]; // $arr_n = [...]; $arr = array_map(function ($item_1, $item_2) { return $item_1 . "_" . $item_2 . "_i"; }, $arr_1, $arr_2); print_r($arr); // ["a_你_i", "b_好_i", "c_嗎_i", "_原_i", "_罪_i"]
是的,遍歷的次數(shù)以最長的數(shù)組為準(zhǔn)。
遍歷3次之后,$arr_1 其實(shí)是完成了的,所以之后 $item_1 的值都是null
以引用傳遞的形式遍歷你的數(shù)組,沒有返回值,而且只能處理一個(gè)數(shù)組。
$arr = ["a", "b", "c"]; array_walk($arr, function (&$item) { $item = $item . "_i"; }); print_r($arr); // ["a_i", "b_i", "c_i"];
注意到 &$item 了嗎,是的,多了個(gè)&,代表著你的形參是以引用傳遞接收數(shù)據(jù)的。你要做的就是想辦法改變這個(gè)參數(shù)。
假如你處理的是二維數(shù)組,處理方式也是萬變不離其宗的。
$arr = [ ["name" => "a"], ["name" => "b"], ["name" => "c"] ]; array_walk($arr, function (&$item) { $item["name"] = $item["name"] . "_i"; }); print_r($arr); // [["name" => "a_i"], ["name" => "b_i"], ["name" => "c_i"]];4、for
這應(yīng)該是超級(jí)通用的語法了
$arr = ["a", "b", "c"]; for ($i = 0; $i < count($arr); ++$i) { $arr[$i] = $arr[$i] . "_i"; } print_r($arr); // ["a_i", "b_i", "c_i"];
不推薦使用。它的效率比不上foreach。而且寫法上比foreach略繁瑣。
5、each哈哈,這個(gè)函數(shù)在PHP7.2已經(jīng)被廢棄了@deprecated,而且感覺特別古老的書寫方式。這種寫法的執(zhí)行效率也不行,新手應(yīng)該直接放棄。
$arr = ["a", "b", "c"]; while (list($key, $value) = each($arr)) { $arr[$key] = $value . "_i"; } print_r($arr); // ["a_i", "b_i", "c_i"];6、reset
準(zhǔn)確的講并不止reset一個(gè)函數(shù),需要組合多個(gè)內(nèi)置函數(shù),平常寫代碼基本是用不上的
$arr = ["a", "b", "c"]; // reset() 指針切換到頭部,其實(shí)默認(rèn)就是指向開頭,可以忽略這句 reset($arr); // current() 獲取當(dāng)前指針的元素值 while ($value = current($arr)) { // key() 獲取當(dāng)前指針的元素下標(biāo) $arr[key($arr)] = $value . "_i"; // next() 指針移到下一個(gè) next($arr); } print_r($arr); // ["a_i", "b_i", "c_i"];
還有什么遍歷方式,歡迎補(bǔ)充。覺得對你有用就點(diǎn)個(gè)贊吧
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/28765.html
摘要:以上是數(shù)組在語言中的定義方法,代表數(shù)組長度為,是數(shù)組中元素的類型,花括號(hào)中的是數(shù)組元素,切記元素個(gè)數(shù)與類型一定要與前面聲明的相符,否則會(huì)報(bào)錯(cuò)。數(shù)組元素的刪除在中刪除數(shù)組元素非常簡單,直接即可,以下代碼是刪除第二個(gè)元素。 數(shù)組的定義 用過PHP的同學(xué)應(yīng)該很清楚,無論多么復(fù)雜的數(shù)據(jù)格式都可以用數(shù)組來表達(dá),什么類型的數(shù)據(jù)都可以往里塞,它是工作必備的一部分,使用很簡單,易用程度簡直變態(tài)。 $a...
摘要:數(shù)組原理遍歷原理揭秘?cái)?shù)組原理遍歷原理揭秘可見,數(shù)組其實(shí)已經(jīng)改變了,但是遍歷出來的并沒有增加的哪一項(xiàng)。此時(shí),我們也可以輸出一下當(dāng)前指針位置數(shù)組原理遍歷原理揭秘?cái)?shù)組原理遍歷原理揭秘?cái)?shù)組指針停留在了位置上。 php中的中的數(shù)組跟js里面數(shù)組是不大一樣的。php中數(shù)組的下標(biāo)可以整數(shù)也可以是字符串,而且數(shù)組中元素的順序不是由下標(biāo)決定的,而是由添加元素的順序。數(shù)組基礎(chǔ) $arr1 = array(...
摘要:支持字符串哈希列表集合有序集合等數(shù)據(jù)結(jié)構(gòu),目前不支持事務(wù)。是多入口以下關(guān)于表驅(qū)動(dòng)法的描述,錯(cuò)誤的是表驅(qū)動(dòng)法可以作為復(fù)雜繼承結(jié)構(gòu)的替代方案,難點(diǎn)在于一個(gè)經(jīng)過深思熟慮的查詢表。表驅(qū)動(dòng)法查找無規(guī)則分布的數(shù)據(jù)采用階梯訪問的方法最佳。 1、有關(guān)PHP字符串的說法,不對的是: CA、如果一個(gè)腳本的編碼是ISO-8859-1,則其中的字符串也會(huì)被編碼為 ISO-8859-1。B、PHP的字符串在內(nèi)部...
摘要:執(zhí)行原理是一門應(yīng)用非常簡單,開發(fā)效率極高的一門語言,其弱類型的變量能省去程序員大量的定義變量類型轉(zhuǎn)換等的時(shí)間和精力。程序最終被翻譯為一組處理函數(shù)的順序執(zhí)行。只有減為時(shí)才會(huì)真正執(zhí)行銷毀操作。 PHP執(zhí)行原理 php是一門應(yīng)用非常簡單,開發(fā)效率極高的一門語言,其弱類型的變量能省去程序員大量的定義變量、類型轉(zhuǎn)換等的時(shí)間和精力。它是一種適用于web開發(fā)的動(dòng)態(tài)語言。 1. php設(shè)計(jì)的原理和特點(diǎn)...
摘要:這種行為比最初出現(xiàn)的問題更為棘手,同時(shí)也是一種常見的錯(cuò)誤源。這意味著這個(gè)數(shù)組的一份拷貝將會(huì)被返回,因此被調(diào)函數(shù)與調(diào)用者所訪問的數(shù)組并不是同樣的數(shù)組實(shí)例。 showImg(https://segmentfault.com/img/bV7reP?w=620&h=620); PHP 語言讓 WEB 端程序設(shè)計(jì)變得簡單,這也是它能流行起來的原因。但也是因?yàn)樗暮唵危琍HP 也慢慢發(fā)展成一個(gè)相對...
閱讀 2826·2023-04-26 02:00
閱讀 2786·2019-08-30 15:54
閱讀 877·2019-08-30 11:15
閱讀 1512·2019-08-29 15:31
閱讀 926·2019-08-29 14:12
閱讀 499·2019-08-29 13:08
閱讀 851·2019-08-27 10:51
閱讀 2719·2019-08-26 12:17