Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/arrays/12.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php中,使用第一个和第二个中的键和值连接两个数组_Php_Arrays_Merge - Fatal编程技术网

Php中,使用第一个和第二个中的键和值连接两个数组

Php中,使用第一个和第二个中的键和值连接两个数组,php,arrays,merge,Php,Arrays,Merge,我有两个数组,一个是从POST方法生成的,另一个是从数据库生成的 Post Array ( [browser] => Array ( [0] => Firefox [1] => Chrome ) [firstname] => Array ( [0] => John ) [lastname] =>

我有两个数组,一个是从POST方法生成的,另一个是从数据库生成的

Post

Array
(
    [browser] => Array
        (
            [0] => Firefox
            [1] => Chrome
        )

    [firstname] => Array
        (
            [0] => John
        )

    [lastname] => Array
        (
            [0] => Doe
        )
)

Database

Array
(
    [0] => stdClass Object
        (
            [title] => Browser Name
            [name] => browser
        )

    [1] => stdClass Object
        (
            [title] => First Name
            [name] => firstname

        )

    [2] => stdClass Object
        (
            [title] => Last Name
            [name] => lastname

        )

)
我希望能够使用POST数组中的键和数据库数组中的名称值来连接这两者

结果应该如下所示:

Array
(
    [0] => stdClass Object
        (
            [title] => Browser Name
            [name] => browser
            [posted] => Array (
                  [0] => Firefox
                  [1] => Chrome
            )
        )

    [1] => stdClass Object
        (
            [title] => First Name
            [name] => firstname
            [posted] => John

        )

    [2] => stdClass Object
        (
            [title] => Last Name
            [name] => lastname
            [posted] => Doe

        )

)
保持Post数组的相同顺序很重要。

尝试以下方法:

$postArray = array(
    'browser' => array('Firefox', 'Chrome'),
    'firstname' => array('John'),
    'lastname' => array('Doe')
);

$arrayObj1 = new StdClass();
$arrayObj1->title = 'Browser Name';
$arrayObj1->name = 'browser';

$arrayObj2 = new StdClass();
$arrayObj2->title = 'First Name';
$arrayObj2->name = 'firstname';

$arrayObj3 = new StdClass();
$arrayObj3->title = 'Last Name';
$arrayObj3->name = 'lastname';

$dbArray = array($arrayObj1, $arrayObj2);

$finalArray = array();
foreach ($dbArray AS $key => $dbObject) {
    $finalArray[$key] = new StdClass();
    $finalArray[$key]->title = $dbObject->title;
    $finalArray[$key]->name = $dbObject->name;
    if (count($postArray[$dbObject->name]) > 1) {
        $finalArray[$key]->posted = $postArray[$dbObject->name];
    } else {
        $finalArray[$key]->posted = $postArray[$dbObject->name][0];
    }
}

var_dump($finalArray);

在那里测试:

发布您当前的代码,从数据库和帖子中获取数据,然后合并两者。@zeflex我没有代码,这就是我寻求帮助的原因。stackoverflow是一个帮助社区。您必须将某些内容作为代码发布,以便在有人可以帮助您之前从某个地方开始;但这只能让我半途而废,你试图合并一个数组和一个对象。它不能工作。必须首先将对象转换为数组。