Risposte:
Si desidera la parse_str
funzione ed è necessario impostare il secondo parametro affinché i dati vengano inseriti in un array anziché in singole variabili.
$get_string = "pg_id=2&parent_id=2&document&video";
parse_str($get_string, $get_array);
print_r($get_array);
?key=lorem&key=ipsum
come se fornissi solo key=ipsum
se quella fosse la stringa di query sull'URL. E penso che sia considerato non valido riutilizzare la chiave e aspettarsi risultati coerenti o che tutte le istanze della chiave vengano conservate. L'approccio valido, almeno per una stringa di query inviata a PHP, sarebbe ?key[]=lorem&key[]=ipsum
, quindi l'approccio nostrano potrebbe cercare eventuali occorrenze in &{x}=
cui x si verifica più di una volta e sostituirlo con x[]
(e trattando? Uguale a &)
?key[]=lorem&key[]=ipsum
alcune settimane fa. Ma grazie per aver condiviso il link!
A volte da parse_str()
solo è preciso delle note, potrebbe essere visualizzato ad esempio:
$url = "somepage?id=123&lang=gr&size=300";
parse_str () restituisce:
Array (
[somepage?id] => 123
[lang] => gr
[size] => 300
)
Sarebbe meglio combinare parse_str()
con parse_url()
questo modo:
$url = "somepage?id=123&lang=gr&size=300";
parse_str( parse_url( $url, PHP_URL_QUERY), $array );
print_r( $array );
$_SERVER['QUERY_STRING']
Usando parse_str()
.
$str = 'pg_id=2&parent_id=2&document&video';
parse_str($str, $arr);
print_r($arr);
Usa http://us1.php.net/parse_str
Attenzione, il suo utilizzo è:
parse_str($str, &$array);
non
$array = parse_str($str);
Se hai problemi a convertire una stringa di query in un array a causa di e commerciali codificate
&
quindi assicurati di usare html_entity_decode
Esempio:
// Input string //
$input = 'pg_id=2&parent_id=2&document&video';
// Parse //
parse_str(html_entity_decode($input), $out);
// Output of $out //
array(
'pg_id' => 2,
'parent_id' => 2,
'document' => ,
'video' =>
)
Esistono diversi metodi possibili, ma per te esiste già una parse_str
funzione integrata
$array = array();
parse_str($string, $array);
var_dump($array);
Questo è il codice PHP per dividere la query in mysql & mssql
enter code here
function splitquery($strquery)
{
$arrquery=explode('select',$strquery);
$stry='';$strx='';
for($i=0;$i<count($arrquery);$i++)
{
if($i==1)
{
echo 'select '.trim($arrquery[$i]);
}
elseif($i>1)
{
$strx=trim($arrquery[($i-1)]);
if(trim(substr($strx,-1))!='(')
{
$stry=$stry.'
select '.trim($arrquery[$i]);
}
else
{
$stry=$stry.trim('select '.trim($arrquery[$i]));
}
$strx='';
}
}
return $stry;
}
Esempio:
seleziona xx da xx seleziona xx, (seleziona xx) da xx dove y = 'cc' seleziona xx da xx left join (seleziona xx) dove (seleziona top 1 xxx da xxx) oder da xxx desc ";
seleziona xx da xx
seleziona xx, (seleziona xx) da xx dove y = 'cc'
selezionare xx da xx join sinistro (selezionare xx) dove (selezionare top 1 xxx da xxx) o da xxx desc
Grazie, dall'Indonesia Sentrapedagang.com
Per questa domanda specifica la risposta scelta è corretta ma se esiste un parametro ridondante, come una "e" extra, nell'URL la funzione fallirà silenziosamente senza generare un errore o un'eccezione:
a=2&b=2&c=5&d=4&e=1&e=2&e=3
Quindi preferisco usare il mio parser in questo modo:
//$_SERVER['QUERY_STRING'] = `a=2&b=2&c=5&d=4&e=100&e=200&e=300`
$url_qry_str = explode('&', $_SERVER['QUERY_STRING']);
//arrays that will hold the values from the url
$a_arr = $b_arr = $c_arr = $d_arr = $e_arr = array();
foreach( $url_qry_str as $param )
{
$var = explode('=', $param, 2);
if($var[0]=="a") $a_arr[]=$var[1];
if($var[0]=="b") $b_arr[]=$var[1];
if($var[0]=="c") $c_arr[]=$var[1];
if($var[0]=="d") $d_arr[]=$var[1];
if($var[0]=="e") $e_arr[]=$var[1];
}
var_dump($e_arr);
// will return :
//array(3) { [0]=> string(1) "100" [1]=> string(1) "200" [2]=> string(1) "300" }
Ora hai tutte le occorrenze di ciascun parametro nel suo array, puoi sempre unirle in un array se vuoi.
Spero che aiuti!
?key=lorem&key=ipsum
si tradurrà inarray(["key"]=>"ipsum")
La domanda è, c'è una funzione per ottenere s.th. come questoarray(["key"]=>array("lorem", "ipsum"))
o devo creare questa funzione da solo?