Я хочу удалить двойную кавычку в моем 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 '[]'; } ?>
Мой результат таков:
[{"id_posiciones":"1",posicion:"1",nick:"biwer",puntos:"1000",uid:"1",pais:"ES",idioma:"ES","device_version":"4"}]
Я хочу удалить двойную кавычку «id_posiciones» и «device_version».
Как я могу сделать для результата:
[{id_posiciones:"1",posicion:"1",nick:"biwer",puntos:"1000",uid:"1",pais:"ES",idioma:"ES",device_version:"4"}]
Если вы добавите символ подчеркивания вашему регулярному выражению в конце, он сделает это.
$array_final = preg_replace('/"([a-zA-Z]+[a-zA-Z0-9_]*)":/','$1:',$array_final);
Я предполагаю, что это то, что preg_replace в любом случае.
Вы можете использовать этот ниже код для удаления цитаты из числового значения.
http://php.net/manual/en/json.constants.php
Он будет работать> = PHP 5.3.
$encoded = json_encode($data, JSON_NUMERIC_CHECK);
Заменить эту строку:
$array_final = preg_replace('/"([a-zA-Z]+[a-zA-Z0-9]*)":/','$1:',$array_final);
от:
$array_final = preg_replace('/"([a-zA-Z_]+[a-zA-Z0-9_]*)":/','$1:',$array_final);
Обратите внимание, что класс regex [a-zA-Z] не соответствует '_'
// 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\"}
Вы можете использовать $.parseJSON
для синтаксического анализа строки и создания Javascript-объекта из нее или еще лучше использовать метод $.getJSON
для его получения