删除json_encode()中的双引号

时间:2022-09-15 16:22:00

I want remove double quote in my json_encode, that is my code:

我想在我的json_encode中删除双引号,这是我的代码:

<?php

require_once 'config.inc.php';
//## Clase Base de Datos
require_once 'Database.class.php';
//## Obtengo los parametros pasados por el metodo GET
$params = $_REQUEST;

$db = new Database(DB_SERVER, DB_USER, DB_PASS, DB_DATABASE);
$db->connect();

$result = mysql_query("SELECT * from ranking WHERE posicion BETWEEN     ".$params['pos_ini']." AND ".$params['pos_fi']) or die('Could not query');

if(mysql_num_rows($result)){
    $array_json=array();
    $filas = mysql_num_rows($result);
    $columnas = mysql_num_fields($result);

    for($i=0;$i<$filas;$i++)
    {
        $fila_dato = mysql_fetch_assoc($result);
        for($k=0;$k<$columnas;$k++)
        {
                    $campo = mysql_field_name($result,$k);
                    $campo = str_replace('\"', '', $campo);
                    $array_json[$i][$campo] = $fila_dato[$campo];
        }
    }
    $array_final = json_encode($array_json);
    $array_final = preg_replace('/"([a-zA-Z]+[a-zA-Z0-9]*)":/','$1:',$array_final);
    echo $array_final;
} else {
    echo '[]';
}
?>

My result is that:

我的结果是:

[{"id_posiciones":"1",posicion:"1",nick:"biwer",puntos:"1000",uid:"1",pais:"ES",idioma:"ES","device_version":"4"}]

I want to remove double quote of "id_posiciones" and "device_version" too.

我想删除“id_posiciones”和“device_version”的双引号。

How can I do for the result is that:

我怎样才能得到结果:

[{id_posiciones:"1",posicion:"1",nick:"biwer",puntos:"1000",uid:"1",pais:"ES",idioma:"ES",device_version:"4"}]

5 个解决方案

#1


4  

If you add an underscore to your regex at the end it will do it.

如果你最后在你的正则表达式中添加一个下划线,它就会这样做。

$array_final = preg_replace('/"([a-zA-Z]+[a-zA-Z0-9_]*)":/','$1:',$array_final);

I assume that's what that preg_replace is for anyway.

我认为这就是preg_replace无论如何。

#2


17  

You can use this bellow code to remove quote from numeric value.

您可以使用此下面的代码从数值中删除引号。

http://php.net/manual/en/json.constants.php

It will work >=PHP 5.3.

它将工作> = PHP 5.3。

$encoded = json_encode($data, JSON_NUMERIC_CHECK);

#3


5  

Replace this line:

替换此行:

 $array_final = preg_replace('/"([a-zA-Z]+[a-zA-Z0-9]*)":/','$1:',$array_final);

by:

$array_final = preg_replace('/"([a-zA-Z_]+[a-zA-Z0-9_]*)":/','$1:',$array_final);

Note that the regex class [a-zA-Z] does not match the '_'

请注意,正则表达式类[a-zA-Z]与“_”不匹配

#4


1  

You can use $.parseJSON to parse the string and create a Javascript object from it, or better yet use a method like $.getJSON to get it

您可以使用$ .parseJSON来解析字符串并从中创建Javascript对象,或者更好地使用$ .getJSON之类的方法来获取它

#5


1  

// use can use addslashes() function for storing in mysql database 
// or remove  slashes  u can use stripslashes() function.

$json_array = array(
'title' => 'Example string\'s with "special" characters'
);

echo $json_decode =addslashes(json_encode($json_array));


output-{\"title\":\"Example string\'s with \\\"special\\\" characters\"}

#1


4  

If you add an underscore to your regex at the end it will do it.

如果你最后在你的正则表达式中添加一个下划线,它就会这样做。

$array_final = preg_replace('/"([a-zA-Z]+[a-zA-Z0-9_]*)":/','$1:',$array_final);

I assume that's what that preg_replace is for anyway.

我认为这就是preg_replace无论如何。

#2


17  

You can use this bellow code to remove quote from numeric value.

您可以使用此下面的代码从数值中删除引号。

http://php.net/manual/en/json.constants.php

It will work >=PHP 5.3.

它将工作> = PHP 5.3。

$encoded = json_encode($data, JSON_NUMERIC_CHECK);

#3


5  

Replace this line:

替换此行:

 $array_final = preg_replace('/"([a-zA-Z]+[a-zA-Z0-9]*)":/','$1:',$array_final);

by:

$array_final = preg_replace('/"([a-zA-Z_]+[a-zA-Z0-9_]*)":/','$1:',$array_final);

Note that the regex class [a-zA-Z] does not match the '_'

请注意,正则表达式类[a-zA-Z]与“_”不匹配

#4


1  

You can use $.parseJSON to parse the string and create a Javascript object from it, or better yet use a method like $.getJSON to get it

您可以使用$ .parseJSON来解析字符串并从中创建Javascript对象,或者更好地使用$ .getJSON之类的方法来获取它

#5


1  

// use can use addslashes() function for storing in mysql database 
// or remove  slashes  u can use stripslashes() function.

$json_array = array(
'title' => 'Example string\'s with "special" characters'
);

echo $json_decode =addslashes(json_encode($json_array));


output-{\"title\":\"Example string\'s with \\\"special\\\" characters\"}