| PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Post your PHP questions here! |
 |

14-09-2010, 14:36
|
|
Hendrik33
Registrierter Benutzer
|
|
Registriert seit: Aug 2010
Beiträge: 70
|
|
JSON Array Problem!
Hallo,
ich habe folgendes Problem:
PHP-Code:
$i=1;
// Tags auslesen
$query=mysql_query("SELECT * FROM name_inserts WHERE ins_picid='1054'", $conn);
$fetch=mysql_fetch_array($query);
// Benutzer Details auslesen
$udquery=mysql_query("SELECT * FROM user WHERE ID='$fetch[ins_uid]'", $conn);
$udfetch=mysql_fetch_array($udquery);
if($udfetch[aktive]=="1") {
$data['tags'][] = array('label' => "$udfetch[nick]", 'x' => $fetch[ins_x], 'y' => $fetch[ins_y], 'h' => 50, 'w' => 50, 'id' => $i );
$i++;
}
$data['tags'][] = array('label' => 'Rachel Green', 'x' => 615, 'y' => 97, 'h' => 50, 'w' => 50, 'id' => 0 );
}
print(json_encode($data));
Ergebnis:
PHP-Code:
{"tags":[
{"label":"Danielx","x":"422","y":"88","h":50,"w":50,"id":1},
{"label":"Rachel Green","x":615,"y":97,"h":50,"w":50,"id":0}]}
Problem!
Wie bekomme ich es hin dass bei Danielx der x und y wert nicht in einem "" ausgegeben werden sondern wie bei Rachel ... ohne "" ...
also anstatt "422" und "88" in 422 bzw 88
DAnke für eure Hilfe
|

14-09-2010, 14:38
|
wahsaga
 Moderator
|
|
Registriert seit: Sep 2001
Beiträge: 24.486
|
|
In dem du die Werte explizit in einen Zahlendatentyp castest, bevor du sie ins Array steckst.
__________________
I don't believe in rebirth. Actually, I never did in my whole lives.
|

14-09-2010, 15:27
|
|
Hendrik33
Registrierter Benutzer
|
|
Registriert seit: Aug 2010
Beiträge: 70
|
|
Frage ist nur wie... Hab bei google nichts gefunden?
|

14-09-2010, 15:29
|
 |
fab-s
Registrierter Benutzer
|
|
Registriert seit: Aug 2010
Beiträge: 28
|
|
Das Suchwort wäre Type Casting gewesen.
PHP-Code:
'x' => (int)$fetch['ins_x']
Edit: hab dir zusätzlich mal den Index 'ins_x' gefixt. Ohne Anführungszeichen versucht PHP sonst, eine Konstante mit Namen ins_x zu benutzen.
Analog ist unter anderem "$udfetch[nick]" und "SELECT * FROM user WHERE ID='$fetch[ins_uid]'" auch verkehrt, solltest Du so ändern:
PHP-Code:
'label' => $udfetch['nick']
PHP-Code:
"SELECT * FROM user WHERE ID='{$fetch['ins_uid']}'"
(wenn du die beiden Queries nicht ohnehin mal mittels JOIN zu einem einzigen machen willst)
Geändert von fab-s (14-09-2010 um 15:36 Uhr)
|

21-09-2010, 13:01
|
|
reok
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Beiträge: 22
|
|
Möglich wäre das Ganze übrigens auch automatisiert (und ggf. mit mehreren "Regeln"):
Du definierst dir hierfür zunächst eine Cast-Regel:
PHP-Code:
function myCast(&$value) { if(ctype_digit($value)) $value = (int)$value; }
In $value ist der aktuelle Wert angegeben, der geprüft werden soll. Entspricht der dem ctype "Digit" (also castable in integer), so wird das cast durchgeführt. Ansonsten bleibt der Wert, so wie er ist.
Um nun diese Regel anzuwenden, wird folgendes benutzt:
PHP-Code:
array_walk($myArray, 'myCast');
Das Array $myArray muss natürlich zunächst gefüllt werden. Die Funktion array_walk läuft durch das Array durch und führt die Callbackt-Funktion "myCast" auf jedes Element an. Die Funktion myCast wurde ja bereits oben definiert. Nach dem Aufruf der array_walk Funktion stehen also nun alle Zahlen korrekt als Integer gecastet, zur Verfügung, ohne dies manuell vornehmen zu müssen.
Denkbar wäre auch die Anwendung mehrer Regeln:
PHP-Code:
function myCast(&$value) { if(ctype_digit($value)) $value = (int)$value; elseif('true' == strtolower($value)) $value = true; elseif('false' == strtolower($value)) $value = false; elseif(empty($value)) $value = null; // etc ... }
Geändert von reok (21-09-2010 um 13:04 Uhr)
|
|
Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
|
|
|
Ähnliche Themen
|
| Thema |
Autor |
Forum |
Antworten |
Letzter Beitrag |
|
Ajax, JSON & Array verständnis frage
|
mcmurphy |
HTML, JavaScript, AJAX und CSS |
2 |
25-08-2010 12:17 |
|
Prototype Json Internet Explorer Problem
|
Turbo |
HTML, JavaScript, AJAX und CSS |
12 |
19-08-2009 01:38 |
|
JSON: Problem mit autoLoad:{url:file.json}
|
neonfly |
HTML, JavaScript, AJAX und CSS |
2 |
25-07-2008 01:00 |
|
JSON-Übergabe-Problem an PHP
|
Mercury1987 |
HTML, JavaScript, AJAX und CSS |
21 |
10-12-2007 12:33 |
|
Seltsames Problem mit Opera, JSON und JS Objekt
|
Günni |
HTML, JavaScript, AJAX und CSS |
6 |
12-07-2007 17:39 |
| Themen-Optionen |
|
|
| Thema bewerten |
|
|
Forumregeln
|
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.
HTML-Code ist aus.
|
|
|
|
PHP News
|