将多个阵列连接在一起

时间:2012-10-11 20:02:07

标签: php arrays

我的表格看起来像那样:

<form method="POST">
    <p>Model 1</p>
        <input name="data_quantity[]">
        <input name="data_consignment[]">
        <input name="data_price[]">

    <p>Model 2</p>
        <input name="data_quantity[]">
        <input name="data_consignment[]">
        <input name="data_price[]">

    <p>Model 3</p>
        <input name="data_quantity[]">
        <input name="data_consignment[]">
        <input name="data_price[]">

    ...
</form>

现在。当我读取PHP上的数据时,我在POST数组中有三个数组($_POST):$_POST['data_quantity'], $_POST['data_consignment'], $_POST['data_price'] ...

我需要将它们合并在一起,所以我计算一个数组中的总数,然后我做for并重新创建数组,并在帖子中的每个数组中使用值。快速举例:

public function build_Lineitems($Quantity=array(), $Consignment=array(), $TransferFrom=array(), $TransferTo=array(), $Price=array(), $Attributes=array()){
    ...

    #   On va boucler sur un des 6 tableaux...
    $Lineitems = array();

    foreach($Quantity as $ModelID => $Lineitem){
        #   Entrée dans le tableau
        if(isset($Lineitems[$ModelID]) === FALSE){
            $Lineitems[$ModelID] = array();
        }

        #   Est-ce que c'est un tableau
        if(is_array($Lineitem) === TRUE){
            foreach($Lineitem as $Entry => $Clone){
                $Lineitems[$ModelID][] = array(
                    'qty'       => (isset($Quantity[$ModelID][$Entry]) === TRUE ? $Quantity[$ModelID][$Entry] : array()),
                    'con'       => (isset($Consignment[$ModelID][$Entry]) === TRUE ? $Consignment[$ModelID][$Entry] : array()),
                    'xferfrom'  => (isset($TransferFrom[$ModelID][$Entry]) === TRUE ? $TransferFrom[$ModelID][$Entry] : array()),
                    'xferto'    => (isset($TransferTo[$ModelID][$Entry]) === TRUE ? $TransferTo[$ModelID][$Entry] : array()),
                    'price'     => (isset($Price[$ModelID][$Entry]) === TRUE ? $Price[$ModelID][$Entry] : array()),
                    'attr'      => (isset($Attributes[$ModelID][$Entry]) === TRUE ? (empty($Attributes[$ModelID][$Entry]) === FALSE ? explode(',', $Attributes[$ModelID][$Entry]) : array()) : array())
                );
            }
        } else {
            #   Okay
            $Lineitems[$ModelID] = array(
                'qty'       => (isset($Quantity[$ModelID]) === TRUE ? $Quantity[$ModelID] : array()),
                'con'       => (isset($Consignment[$ModelID]) === TRUE ? $Consignment[$ModelID] : array()),
                'xferfrom'  => (isset($TransferFrom[$ModelID]) === TRUE ? $TransferFrom[$ModelID] : array()),
                'xferto'    => (isset($TransferTo[$ModelID]) === TRUE ? $TransferTo[$ModelID] : array()),
                'price'     => (isset($Price[$ModelID]) === TRUE ? $Price[$ModelID] : array()),
                'attr'      => array()
            );
        }
    }

    #   On renvoie
    return $Lineitems;
}

我的问题是,有更清洁的方法吗?谢谢。 (这:多个数组的合并部分。

2 个答案:

答案 0 :(得分:1)

您可以首先发布多维值:

<input name="data[quantity][]">

或者采用不同的等级顺序(在计算$i时):

<input name="data[<?php echo $i; ?>][quantity]">

答案 1 :(得分:0)

您是否考虑过将array_merge或其递归兄弟合并在一起的所有内容? 虽然你应该小心不要直接在$ _POST上使用它来获取不需要的数据