我需要从特定代码中删除数组中的重复项

时间:2011-10-18 00:58:44

标签: php arrays

我有以下代码:

public function ajax()
{
    // Contains results
    $data = array();
    if( isset($this->request->get['keyword']) ) {
        // Parse all keywords to lowercase
        $keywords = strtolower( $this->request->get['keyword'] );
        // Perform search only if we have some keywords
        if( strlen($keywords) >= 3 ) {
            $parts = explode( ' ', $keywords );
            $add = '';
            // Generating search
            foreach( $parts as $part ) {
                $add .= ' AND (LOWER(pd.name) LIKE "%' . $this->db->escape($part) . '%"';
                $add .= ' OR LOWER(p.model) LIKE "%' . $this->db->escape($part) . '%")';
            }
            $add = substr( $add, 4 );
            $sql  = 'SELECT pd.product_id, pd.name, p.model FROM ' . DB_PREFIX . 'product_description AS pd ';
            $sql .= 'LEFT JOIN ' . DB_PREFIX . 'product AS p ON p.product_id = pd.product_id ';
            $sql .= 'LEFT JOIN ' . DB_PREFIX . 'product_to_store AS p2s ON p2s.product_id = pd.product_id ';
            $sql .= 'WHERE ' . $add . ' AND p.status = 1 ';
            $sql .= ' AND p2s.store_id =  ' . (int)$this->config->get('config_store_id'); 
            $sql .= ' ORDER BY LOWER(pd.name) ASC, LOWER(p.model) ASC';
            $sql .= ' LIMIT 15';
            $res = $this->db->query( $sql );
            if( $res ) {
                $data = ( isset($res->rows) ) ? $res->rows : $res->row;

                // For the seo url stuff
                $basehref = 'product/product&keyword=' . $this->request->get['keyword'] . '&product_id=';
                foreach( $data as $key => $values ) {
                    $data[$key] = array(
                        'name' => htmlspecialchars_decode($values['name'] . ' (' . $values['model'] . ')', ENT_QUOTES),
                        'href' => $this->url->link($basehref . $values['product_id'])
                    );
                }
            }
        }
    }
    echo json_encode( $data );
}

因此,该数组会生成一个产品列表,例如:

Apple MacBook(产品型号10)

AppleМакБук(产品型号10)

问题是这两个产品实际上是同一个产品(相同的 product_id )但是使用不同的语言,并且两者都有相同的网址。

因此,我想检查的是,在制作数组时,检查数组中是否已存在 product_id 的产品的代码,以及有,不要添加另一个具有相同的 product_id

实际上,我不希望数组生成两个或多个具有相同 product_id 的产品。

编辑:随着Marc的代码和ghbarratt建议像魅力一样工作。万分感谢你们,以及你们所有人。

P.S。如何为 ORDER BY pd.language_id 添加ASC或DESC:

$sql .= ' ORDER BY pd.language_id = ' . (int)$this->config->get('config_language_id');

$sql .= ' , LOWER(pd.name) ASC, LOWER(p.model) ASC';

3 个答案:

答案 0 :(得分:1)

$data = array();
foreach ($res->rows as $values) {
    $data[$values['product_id']] = array(
        'name' => ...,
        'href' => ...
    );
}

仅保证独特的产品ID。

答案 1 :(得分:0)

最简单的方法应该是添加另一个数组来跟踪已写入的ID并使用http://php.net/manual/en/function.in-array.php进行检查:

$basehref = 'product/product&keyword=' . $this->request->get['keyword'] . '&product_id=';
$writtenIds = array();
foreach( $data as $key => $values ) {
    if(in_array($values['product_id'], $writtenIds)) 
    { 
        unset($data[$key]); 
        continue; 
    }
    $data[$key] = array(
        'name' => htmlspecialchars_decode($values['name'] . ' (' . $values['model'] . ')', ENT_QUOTES),
        'href' => $this->url->link($basehref . $values['product_id'])
    );
    $writtenIds[] = $values['product_id'];
}

答案 2 :(得分:0)

这个答案类似于Marc的,除了它将在product_id的数据数组的其他元素中保留其他名称,并且它将确保删除与第一个遇到的product_id具有相同product_id的子数组,我相信这是你想要做的重要部分。

$product_ids_added = array();

foreach( $data as $key => $values ) {

        $original_key = array_search($values['product_id'], $product_ids_added);

        if($original_key===false) {
                $data[$key] = array(
                        'name' => htmlspecialchars_decode($values['name'] . ' (' . $values['model'] . ')', ENT_QUOTES),
                        'href' => $this->url->link($basehref . $values['product_id'])
                );
                $product_ids_added[] = $values['product_id'];
        }
        else {
                unset($data[$key]);
                if(!isset($data[$original_key]['additional_names'])) $data[$original_key]['additional_names'] = array();
                $data[$original_key]['additional_names'][] = htmlspecialchars_decode($values['name'] . ' (' . $values['model'] . ')', ENT_QUOTES);
        }

}