php數(shù)組中指定一列求和用array_column()和array_sum()函數(shù)。步驟:1、用array_column()獲取數(shù)組中指定一列的全部元素,語法“array_column(數(shù)組, '指定列名')”,會返回一個包含全部元素的結(jié)果數(shù)組;2、用array_sum()函數(shù)計算結(jié)果數(shù)組中所有元素的和即可,語法“array_sum(結(jié)果數(shù)組)”。
本教程操作環(huán)境:windows7系統(tǒng)、PHP8版、DELL G3電腦
php數(shù)組中指定一列求和用array_column()和array_sum()函數(shù)。
-
array_column()函數(shù)可以獲取數(shù)組中指定一列的全部元素
-
array_sum()函數(shù)可計算數(shù)組中所有元素的和
實現(xiàn)步驟:
步驟1:使用array_column()函數(shù)指定數(shù)組中指定一列的值
array_column() 可以返回指定數(shù)組中某個單一列的值;會返回一個數(shù)組,數(shù)組值為就是指定一列的值。
<?php header('content-type:text/html;charset=utf-8'); $user = array( '0' => array('id' => 100, 'username' => 'a1'), '1' => array('id' => 101, 'username' => 'a2'), '2' => array('id' => 102, 'username' => 'a3'), '3' => array('id' => 103, 'username' => 'a4'), '4' => array('id' => 104, 'username' => 'a5'), ); var_dump($user); $id=array_column($user, 'id'); var_dump($id); ?>
步驟2:使用array_sum()對結(jié)果數(shù)組求和
array_sum() 函數(shù)可以計算指定數(shù)組中所有元素的和
$sum=array_sum($id); echo "多維數(shù)組中id列的和:".array_sum($id);
擴展知識:array_product()函數(shù)
array_sum()函數(shù)可以計算數(shù)組元素總和,而array_product()函數(shù)可以計算數(shù)組元素乘積。
<?php $array= array(2,3,4); echo '2 * 3 * 4 = '. array_product($array); $array= array(3,4,5); echo '<br>3 * 4 * 5 = '. array_product($array); $array= array(1,2,3,4,5,6,7,8,9,10); echo '<br>1 * 2 * 3 *...* 9 * 10 = '. array_product($array); ?>
輸出結(jié)果:
如果$array
中存在非數(shù)值類型的元素,那么PHP會將它們轉(zhuǎn)換成一個數(shù)值(隱性數(shù)據(jù)類型轉(zhuǎn)換),轉(zhuǎn)換失敗就作為 0 值。
<?php $array= array(2,"3.1",4); echo '2 * 3.1 * 4 = '. array_product($array); $array= array(3,"10.abc",5); echo '<br>3 * "10.abc" * 5 = 3 * 10 * 5 ='. array_product($array); $array= array(3,"hello",5); echo '<br>3 * "hello" * 5 = 3 * 0 * 5 ='. array_product($array); ?>
-
字符串"3.1"會被轉(zhuǎn)換成小數(shù) 3.1 ,所以第一個數(shù)組的元素乘積為24.8。
-
字符串 "10abc" 會被轉(zhuǎn)換成整數(shù) 10,所以第二個數(shù)組的元素乘積為150。
-
字符串“hello”無法被轉(zhuǎn)換成整數(shù),因此作為 0 值,繼而第三個數(shù)組的元素乘積為0。
輸出結(jié)果:
推薦學(xué)習(xí):《PHP視頻教程》