0

我正在尝试使用此功能将丹麦语字符转换为 utf

private function process_elements($element){
   $element=  strtolower ( trim ( $element ) );
   $element=  mysql_real_escape_string($element);
    return utf8_encode($element);
}

我的数组在没有这样的编码的情况下使用:

Array ( [0] => Desktop [1] => imlive [2] => dk [3] => Danish [4] => Denmark [5] => http://www.google.dk/search?ie=UTF-8&oe=UTF-8&hl=da&q=imlive&adtest=on&gl=DK&glp=1&ip=0.0.0.0&pws=0&noj=1&nomo=1 [6] => ImLive - Fr�kke cam-piger [7] => Tusindvis af rigtige amat�rer live! [8] => Fra private hjem og sovev�relser [9] => dk.imlive.com [10] => ImLive - Fr�kke cam-piger [11] => dk.imlive.com [12] => Tusindvis af rigtige amat�rer live! Fra private hjem og sovev�relser [13] => ImLive - Fr�kke cam-piger - Tusindvis af rigtige amat�rer live! [14] => dk.imlive.com [15] => Fra private hjem og sovev�relser [16] => ImLive - Fr�kke cam-piger [17] => Tusindvis af rigtige amat�rer live! Fra private hjem og sovev�relser [18] => dk.imlive.com )

这是我的实现:

array_map('self::process_elements', $data);

该函数在一个类中......

后来我设置了这样的查询。例如:

        mysql_query("SET NAMES 'utf8'");
         $query="INSERT INTO advert
                 SET device='$device',
                 keyword='$keyword',
                 google_domain='$google_domain',
                 language='$language',
                 country='$country',
                 check_url='$check_url',
                 task_id=$this->task_id";

       mysql_query($query) or die(myql_error());

但它会抛出 a 字符错误的异常.. 因为在我输入 thtem 之前,它们不是 utf .. 为什么数组映射函数不起作用?!

4

3 回答 3

2

看看这个线程:将对象方法传递给 array_map()

尝试:

array_map(array($this, $this->process_elements), $data);
于 2012-06-11T11:44:46.060 回答
1

引用自 php.net

如果您需要从 array_map 调用静态方法,这将不起作用:

<?PHP array_map('myclass::myMethod' , $value); ?>

相反,您需要这样做:

<?PHP array_map( array('myclass','myMethod') , $value); ?>

请记住,这将适用于任何需要回调参数的 PHP 函数。

http://php.net/manual/de/function.array-map.php

于 2012-06-11T11:43:29.487 回答
1

您不能更改该数组中的初始值,因为 array_map() 返回一个具有更改值的新数组,它不是通过引用传递的。

$newArray = array_map('self::process_elements', $data);
于 2012-06-11T11:47:02.703 回答