Php 将两个数组合并或组合为单个数组
我有一个创建或合并两个阵列到单个阵列的案例 第一个数组如下:Php 将两个数组合并或组合为单个数组,php,arrays,merge,Php,Arrays,Merge,我有一个创建或合并两个阵列到单个阵列的案例 第一个数组如下: Array // First Array ( [0] => Array ( [hotel] => cempaka [vendor] => mas ) [1] => Array ( [hotel] => permata [vendor] =>
Array // First Array
(
[0] => Array
(
[hotel] => cempaka
[vendor] => mas
)
[1] => Array
(
[hotel] => permata
[vendor] => sip
)
)
第二个阵列:
Array
(
[0] => Array
(
[order_type] => 1
[currency] => 26
[net] => 26000
[rate] => 26000
[amount] => 26000
[bank_surcharge] => 26000
[ticket] => 26000
[profit] => 26000
[selling_price] => 26000
[description] => a
)
[1] => Array
(
[order_type] => 2
[currency] => 27
[net] => 27000
[rate] => 27000
[amount] => 27000
[bank_surcharge] => 27000
[ticket] => 27000
[profit] => 27000
[selling_price] => 27000
[description] => b
)
[2] => Array
(
[order_type] => 5
[currency] => 28
[net] => 28000
[rate] => 28000
[amount] => 28000
[bank_surcharge] => 28000
[ticket] => 28000
[profit] => 28000
[selling_price] => 28000
[description] => c
)
[3] => Array
(
[order_type] => 3
[currency] => 29
[net] => 29000
[rate] => 29000
[amount] => 29000
[bank_surcharge] => 29000
[ticket] => 29000
[profit] => 29000
[selling_price] => 29000
[description] => d
)
[4] => Array
(
[order_type] => 4
[currency] => 30
[net] => 30000
[rate] => 30000
[amount] => 30000
[bank_surcharge] => 30000
[ticket] => 30000
[profit] => 30000
[selling_price] => 30000
[description] => e
)
[5] => Array
(
[order_type] => 6
[currency] => 31
[net] => 31000
[rate] => 31000
[amount] => 31000
[bank_surcharge] => 31000
[ticket] => 31000
[profit] => 31000
[selling_price] => 31000
[description] => f
)
[6] => Array
(
[order_type] => 1
[currency] => 32
[net] => 32000
[rate] => 32000
[amount] => 32000
[bank_surcharge] => 32000
[ticket] => 32000
[profit] => 32000
[selling_price] => 32000
[description] => g
)
[7] => Array
(
[order_type] => 2
[currency] => 33
[net] => 33000
[rate] => 33000
[amount] => 33000
[bank_surcharge] => 33000
[ticket] => 33000
[profit] => 33000
[selling_price] => 33000
[description] => h
)
[8] => Array
(
[order_type] => 5
[currency] => 34
[net] => 34000
[rate] => 34000
[amount] => 34000
[bank_surcharge] => 34000
[ticket] => 34000
[profit] => 34000
[selling_price] => 34000
[description] => i
)
[9] => Array
(
[order_type] => 3
[currency] => 35
[net] => 35000
[rate] => 35000
[amount] => 35000
[bank_surcharge] => 35000
[ticket] => 35000
[profit] => 35000
[selling_price] => 35000
[description] => j
)
[10] => Array
(
[order_type] => 4
[currency] => 36
[net] => 36000
[rate] => 36000
[amount] => 36000
[bank_surcharge] => 36000
[ticket] => 36000
[profit] => 36000
[selling_price] => 36000
[description] => k
)
[11] => Array
(
[order_type] => 6
[currency] => 37
[net] => 37000
[rate] => 37000
[amount] => 37000
[bank_surcharge] => 37000
[ticket] => 37000
[profit] => 37000
[selling_price] => 37000
[description] => l
)
)
然后这就是我想要得到的输出:
Array
(
[0] => Array
(
[hotel] => cempaka
[vendor] => mas
[order_type] => 1
[currency] => 26
[net] => 26000
[rate] => 26000
[amount] => 26000
[bank_surcharge] => 26000
[ticket] => 26000
[profit] => 26000
[selling_price] => 26000
[description] => a
)
[1] => Array
(
[hotel] => cempaka
[vendor] => mas
[order_type] => 2
[currency] => 27
[net] => 27000
[rate] => 27000
[amount] => 27000
[bank_surcharge] => 27000
[ticket] => 27000
[profit] => 27000
[selling_price] => 27000
[description] => b
)
[2] => Array
(
[hotel] => cempaka
[vendor] => mas
[order_type] => 5
[currency] => 28
[net] => 28000
[rate] => 28000
[amount] => 28000
[bank_surcharge] => 28000
[ticket] => 28000
[profit] => 28000
[selling_price] => 28000
[description] => c
)
[3] => Array
(
[hotel] => cempaka
[vendor] => mas
[order_type] => 3
[currency] => 29
[net] => 29000
[rate] => 29000
[amount] => 29000
[bank_surcharge] => 29000
[ticket] => 29000
[profit] => 29000
[selling_price] => 29000
[description] => d
)
[4] => Array
(
[hotel] => cempaka
[vendor] => mas
[order_type] => 4
[currency] => 30
[net] => 30000
[rate] => 30000
[amount] => 30000
[bank_surcharge] => 30000
[ticket] => 30000
[profit] => 30000
[selling_price] => 30000
[description] => e
)
[5] => Array
(
[hotel] => cempaka
[vendor] => mas
[order_type] => 6
[currency] => 31
[net] => 31000
[rate] => 31000
[amount] => 31000
[bank_surcharge] => 31000
[ticket] => 31000
[profit] => 31000
[selling_price] => 31000
[description] => f
)
[6] => Array
(
[hotel] => permata
[vendor] => sip
[order_type] => 1
[currency] => 32
[net] => 32000
[rate] => 32000
[amount] => 32000
[bank_surcharge] => 32000
[ticket] => 32000
[profit] => 32000
[selling_price] => 32000
[description] => g
)
[7] => Array
(
[hotel] => permata
[vendor] => sip
[order_type] => 2
[currency] => 33
[net] => 33000
[rate] => 33000
[amount] => 33000
[bank_surcharge] => 33000
[ticket] => 33000
[profit] => 33000
[selling_price] => 33000
[description] => h
)
[8] => Array
(
[hotel] => permata
[vendor] => sip
[order_type] => 5
[currency] => 34
[net] => 34000
[rate] => 34000
[amount] => 34000
[bank_surcharge] => 34000
[ticket] => 34000
[profit] => 34000
[selling_price] => 34000
[description] => i
)
[9] => Array
(
[hotel] => permata
[vendor] => sip
[order_type] => 3
[currency] => 35
[net] => 35000
[rate] => 35000
[amount] => 35000
[bank_surcharge] => 35000
[ticket] => 35000
[profit] => 35000
[selling_price] => 35000
[description] => j
)
[10] => Array
(
[hotel] => permata
[vendor] => sip
[order_type] => 4
[currency] => 36
[net] => 36000
[rate] => 36000
[amount] => 36000
[bank_surcharge] => 36000
[ticket] => 36000
[profit] => 36000
[selling_price] => 36000
[description] => k
)
[11] => Array
(
[hotel] => permata
[vendor] => sip
[order_type] => 6
[currency] => 37
[net] => 37000
[rate] => 37000
[amount] => 37000
[bank_surcharge] => 37000
[ticket] => 37000
[profit] => 37000
[selling_price] => 37000
[description] => l
)
)
(这两个数组是我从javascript生成的动态字段中得到的)
任何解决方案都将不胜感激。。谢谢试试看
$arr_cnt = count($arr1);
for($i = 0 ; $i < $arr_cnt ; $i++) {
foreach($arr1[$i] as $key1 => $value1) {
$new_arr[$i][$key1] = $value1;
}
foreach($arr2[$i] as $key2 => $value2) {
$new_arr[$i][$key2] = $value2;
}
}
print_r($new_arr);
$arr\u cnt=count($arr1);
对于($i=0;$i<$arr\u cnt;$i++){
foreach($arr1[$i]作为$key1=>$value1){
$new_arr[$i][$key1]=$value1;
}
foreach($arr2[$i]作为$key2=>$value2){
$new_arr[$i][$key2]=$value2;
}
}
打印(新的);
由于您试图根据第二个数组的键号合并数组,请使用以下命令:
foreach($second_array as $key => $value){
if($key >= 0 && $key <= 5){
$new_array[$key] = array_merge($second_array[$key], $first_array[0]);
}
if($key >= 6 && $key <= 11){
$new_array[$key] = array_merge($second_array[$key], $first_array[1]);
}
//etc.......
}
foreach($key=>value的第二个数组){
如果($key>=0&&$key=6&&$key,就像我在下面的帖子中说的,这是我从dynamic multi field中得到的两个数组(我没有完整显示我的代码,因为我担心这会花很长时间)。因此,基本上,我有javascript和html的多字段表单,我想用php将其值传递给数组。这样我可以在屏幕上显示它或将其插入db。假设第一个数组是heads,第二个数组是items。如果heads[0],则它将与items[0]合并,直到items[5]。如果heads[1],则它将与items[6]合并,直到items[11].如果是头[3],它将与项目[12]合并,直到项目[17]等等..有什么帮助吗?上面的代码满足我的需要吗?先生:)但是如何使它动态循环(//等..我需要它动态)有什么想法吗,解决方案,先生?@Lloyd Banks我终于可以让它变得动态了,先生,谢谢你的解决方案。你试过我的答案了吗?它不能给我我想要的输出。所以,基本上,我有javascript和html的多字段表单,我想用php将它的值传递给数组。这样我就可以在屏幕上显示它或将它插入数据库。比如说,第一个数组is heads和第二个数组是items。如果heads[0],则它将与items[0]合并,直到items[5]。如果heads[1],则它将与items[6]合并,直到items[11]。如果heads[3],则它将与items[12]合并,直到items[17]等等..有什么帮助吗,先生?我希望它是动态的,先生..我尝试了上面的代码,但没有达到我需要的效果..所以,基本上,我有javascript和html的多字段表单,我想用php将它的值传递给数组。这样我就可以在屏幕上显示它或将它插入数据库。假设第一个数组是heads,第二个数组是items。如果heads[0]然后它将与项目[0]合并,直到项目[5]。如果是标题[1],它将与项目[6]合并,直到项目[11]。如果是标题[3],它将与项目[12]合并,直到项目[17]等等..有什么帮助吗,先生?给我想要的输出不起作用。所以,基本上,我有javascript和html的多字段表单,我想用php将它的值传递给数组。这样我可以在屏幕上显示它或将它插入数据库。假设第一个数组是heads,第二个数组是items。如果heads[0],那么它将与items[0]合并,直到items[5]。如果是标题[1],则它将与项目[6]合并,直到项目[11]。如果是标题[3],则它将与项目[12]合并,直到项目[17],依此类推。先生,有什么帮助吗?
$outputArray = array();
foreach ($firstArray as $location) {
foreach ($secondArray as $option) {
$outputArray[] = array_merge($location,$option);
}
}