string(4) "" />     string(4) "">
Rumah pembangunan bahagian belakang tutorial php 数组中对某项雷同的值进行求和计算

数组中对某项雷同的值进行求和计算

Jun 13, 2016 pm 12:27 PM
array float gt nbsp string

数组中对某项相同的值进行求和计算
已知数组:

$arr = array(15) {<br />  [0]=><br />  array(9) {<br />    ["lppt"]=><br />    string(4) "LP1 "<br />    ["fg_type"]=><br />    string(5) "ECU  "<br />    ["customer_no"]=><br />    string(4) "A001"<br />    ["etype1"]=><br />    string(3) "DIG"<br />    ["RevDegree"]=><br />    string(2) "S "<br />    ["item1"]=><br />    float(8810)<br />    ["rs1"]=><br />    float(5787788.527)<br />    ["item2"]=><br />    float(8928)<br />    ["rs2"]=><br />    float(5865309.4176)<br />  }<br />  [1]=><br />  array(9) {<br />    ["lppt"]=><br />    string(4) "LP1 "<br />    ["fg_type"]=><br />    string(3) "ECU"<br />    ["customer_no"]=><br />    string(4) "A001"<br />    ["etype1"]=><br />    string(3) "MPI"<br />    ["RevDegree"]=><br />    string(1) "B"<br />    ["item1"]=><br />    float(0)<br />    ["rs1"]=><br />    float(0)<br />    ["item2"]=><br />    float(0)<br />    ["rs2"]=><br />    float(0)<br />  }<br />  [2]=><br />  array(9) {<br />    ["lppt"]=><br />    string(4) "LP1 "<br />    ["fg_type"]=><br />    string(4) "ECU "<br />    ["customer_no"]=><br />    string(4) "A001"<br />    ["etype1"]=><br />    string(3) "MPI"<br />    ["RevDegree"]=><br />    string(2) "S "<br />    ["item1"]=><br />    float(63485)<br />    ["rs1"]=><br />    float(23211270.7503)<br />    ["item2"]=><br />    float(71973)<br />    ["rs2"]=><br />    float(26689668.0654)<br />  }<br />  [3]=><br />  array(9) {<br />    ["lppt"]=><br />    string(4) "LP1 "<br />    ["fg_type"]=><br />    string(4) "ECU "<br />    ["customer_no"]=><br />    string(4) "A002"<br />    ["etype1"]=><br />    string(3) "MPI"<br />    ["RevDegree"]=><br />    string(2) "S "<br />    ["item1"]=><br />    float(4810)<br />    ["rs1"]=><br />    float(2329072.60146)<br />    ["item2"]=><br />    float(5855)<br />    ["rs2"]=><br />    float(2783605.29921)<br />  }<br />  [4]=><br />  array(9) {<br />    ["lppt"]=><br />    string(4) "LP1 "<br />    ["fg_type"]=><br />    string(5) "ECU  "<br />    ["customer_no"]=><br />    string(4) "A004"<br />    ["etype1"]=><br />    string(3) "MPI"<br />    ["RevDegree"]=><br />    string(2) "S "<br />    ["item1"]=><br />    float(1716)<br />    ["rs1"]=><br />    float(652004.847)<br />    ["item2"]=><br />    float(1711)<br />    ["rs2"]=><br />    float(647801.6757)<br />  }<br />[5]=><br />  array(9) {<br />    ["lppt"]=><br />    string(4) "LP2 "<br />    ["fg_type"]=><br />    string(3) "ECU"<br />    ["customer_no"]=><br />    string(4) "A001"<br />    ["etype1"]=><br />    string(3) "MPI"<br />    ["RevDegree"]=><br />    string(1) "B"<br />    ["item1"]=><br />    float(0)<br />    ["rs1"]=><br />    float(0)<br />    ["item2"]=><br />    float(0)<br />    ["rs2"]=><br />    float(0)<br />  }<br />};
Salin selepas log masuk


求当fg_type项相同时,针对item1,item2,rs1,rs2项的求和,并将求得的结果放在此数组后。
------解决思路----------------------
	$arr = array(<br />		array('fg_type'=>'ECU1', 'item1'=>8810, 'rs1'=>5787788.527, 'item2'=>8928, 'rs2'=>5865309.4176),<br />		array('fg_type'=>'ECU1', 'item1'=>0, 'rs1'=>0, 'item2'=>0, 'rs2'=>0),<br />		array('fg_type'=>'ECU2', 'item1'=>63485, 'rs1'=>23211270.7503, 'item2'=>71973, 'rs2'=>26689668.0654),<br />		array('fg_type'=>'ECU2', 'item1'=>4810, 'rs1'=>2329072.60146, 'item2'=>5855, 'rs2'=>2783605.29921),<br />		array('fg_type'=>'ECU3', 'item1'=>1716, 'rs1'=>652004.847, 'item2'=>1711, 'rs2'=>647801.6757),<br />		array('fg_type'=>'ECU3', 'item1'=>0, 'rs1'=>0, 'item2'=>0, 'rs2'=>0),<br />	);<br />	<br />	$new_arr = array();<br /> 	for($i=0; $i<count($arr); $i++){<br />		$arr[$i]['sum'] = $arr[$i]['item1'] + $arr[$i]['rs1'] + $arr[$i]['item2'] + $arr[$i]['rs2'];<br />		$new_arr[$arr[$i]['fg_type']] = 0;<br />	}<br />	<br />	for($i=0; $i<count($arr); $i++){<br />		if(array_key_exists($arr[$i]['fg_type'], $new_arr)){<br />			$new_arr[$arr[$i]['fg_type']] += $arr[$i]['sum'];<br />		}<br />	}<br />	<br />	array_push($arr,$new_arr);<br />	<br />	echo '<pre class="brush:php;toolbar:false">';<br />	print_r($arr);
Salin selepas log masuk

测试结果应该没问题,不知道这么写好不好,凑合着看...

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Penyelesaian: Organisasi anda memerlukan anda menukar PIN anda Penyelesaian: Organisasi anda memerlukan anda menukar PIN anda Oct 04, 2023 pm 05:45 PM

Penyelesaian: Organisasi anda memerlukan anda menukar PIN anda

Cara melaraskan tetapan sempadan tetingkap pada Windows 11: Tukar warna dan saiz Cara melaraskan tetapan sempadan tetingkap pada Windows 11: Tukar warna dan saiz Sep 22, 2023 am 11:37 AM

Cara melaraskan tetapan sempadan tetingkap pada Windows 11: Tukar warna dan saiz

Bagaimana untuk mendayakan atau melumpuhkan pratonton lakaran kecil bar tugas pada Windows 11 Bagaimana untuk mendayakan atau melumpuhkan pratonton lakaran kecil bar tugas pada Windows 11 Sep 15, 2023 pm 03:57 PM

Bagaimana untuk mendayakan atau melumpuhkan pratonton lakaran kecil bar tugas pada Windows 11

Bagaimana untuk menukar warna bar tajuk pada Windows 11? Bagaimana untuk menukar warna bar tajuk pada Windows 11? Sep 14, 2023 pm 03:33 PM

Bagaimana untuk menukar warna bar tajuk pada Windows 11?

Apakah perbezaan antara Huawei GT3 Pro dan GT4? Apakah perbezaan antara Huawei GT3 Pro dan GT4? Dec 29, 2023 pm 02:27 PM

Apakah perbezaan antara Huawei GT3 Pro dan GT4?

Paparkan panduan penskalaan pada Windows 11 Paparkan panduan penskalaan pada Windows 11 Sep 19, 2023 pm 06:45 PM

Paparkan panduan penskalaan pada Windows 11

10 Cara untuk Melaraskan Kecerahan pada Windows 11 10 Cara untuk Melaraskan Kecerahan pada Windows 11 Dec 18, 2023 pm 02:21 PM

10 Cara untuk Melaraskan Kecerahan pada Windows 11

Bagaimana untuk mematikan pengesahan penyemakan imbas peribadi pada iPhone dalam Safari? Bagaimana untuk mematikan pengesahan penyemakan imbas peribadi pada iPhone dalam Safari? Nov 29, 2023 pm 11:21 PM

Bagaimana untuk mematikan pengesahan penyemakan imbas peribadi pada iPhone dalam Safari?

See all articles