Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
A New York HP ha messo al centro della scena HP IQ, la piattaforma di IA locale da 20 miliardi di parametri. L’abbiamo vista in funzione: è uno strumento che funziona, pensato per un target specifico, con vantaggi reali e limiti altrettanto evidenti
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
La PNY GeForce RTX 5080 Slim OC si distingue nel panorama delle GPU di fascia alta per il design compatto a due slot, ispirato alla NVIDIA GeForce RTX 5080 Founders Edition. In questo test analizziamo comportamento termico e prestazioni in gioco, valutando se il formato ridotto comprometta o meno l'esperienza complessiva rispetto alle soluzioni più ingombranti presenti sul mercato.
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-02-2014, 20:39   #1
stefano861
Member
 
Iscritto dal: Nov 2013
Messaggi: 62
[PHP] Ordinare array multidimensionale associativo

Ciao a tutti, ho un array multidimensionale come questo:

array $friends:
Codice:
Array ( 
	[0] => User Object ( 
				[id:User:private] => 6 
				[username:User:private] => amy
				[password:User:private] => fa7f8ff03a1b3d214913bbce87b4b1a1a95cbf79 
				[email:User:private] => [email protected] 
				[first_name:User:private] => Amy
				[last_name:User:private] => Ross 
				[city:User:private] => Los Angeles 
				[gender:User:private] => F 
				[date:User:private] => 01/01/2000 
		) 
	[1] => User Object ( 
				[id:User:private] => 12 
				[username:User:private] => antony 
				[password:User:private] => 1799296195846afeef14df836a5db11994803780 
				[email:User:private] => [email protected] 
				[first_name:User:private] => Antony 
				[last_name:User:private] => Hevia 
				[city:User:private] => New York 
				[gender:User:private] => M 
				[date:User:private] => 01/01/2003 
		) 
	[2] => User Object ( 
				[id:User:private] => 17 
				[username:User:private] => janis 
				[password:User:private] => e74f86fd784cbedb3cf1e4e1f685a12470fff7bc 
				[email:User:private] => [email protected] 
				[first_name:User:private] => Janis 
				[last_name:User:private] => Jane 
				[city:User:private] => // 
				[gender:User:private] => F 
				[date:User:private] => ../../.... 
		) 
	[3] => User Object ( 
				[id:User:private] => 19 
				[username:User:private] => alex 
				[password:User:private] => e74f86fd784cbedb3cf1e4e1fa5db11994803780 
				[email:User:private] => [email protected] 
				[first_name:User:private] => Alex 
				[last_name:User:private] => Smith
				[city:User:private] => // 
				[gender:User:private] => F 
				[date:User:private] => ../../.... 
		) 		
}
Voglio ordinare l'array secondo il campo username e first_name.

Ho provato così:

Codice:
$this->sort($this->friends, array('username', 'first_name'));

public function sort($array, $cols) { 
   $colarr = array(); 
   foreach($cols as $col => $order) { 
       $colarr[$col] = array(); 
       foreach($array as $k => $row) { 
          $colarr[$col]['_'.$k] = strtolower($row[$col]);  -->line 112
       } 
   } 
   $eval = 'array_multisort('; 
   foreach($cols as $col => $order) { 
       $eval .= '$colarr[\''.$col.'\'],'.$order.','; 
   } 
   $eval = substr($eval,0,-1).');'; 
   eval($eval); 
   $ret = array(); 
   foreach($colarr as $col => $arr) { 
       foreach($arr as $k => $v) { 
           $k = substr($k,1); 
           if(!isset($ret[$k])) 
              $ret[$k] = $array[$k]; 
           $ret[$k][$col] = $array[$k][$col]; 
       } 
   } 
   return $ret; 
}
Ma genera il seguente errore:

Fatal error: Cannot use object of type User as array in ... on line 112

Come posso risolvere?

Altrimento ho pensato di ordinare l'array al momento della celect al database.
Questa è la mia query:
Codice:
$stmt = $db->prepare("SELECT * "
                . "FROM `users` "
                . "INNER JOIN `friend` ON (`username` = `user_req`) "
                . "WHERE (`user_acc` = ? AND `status` = '1') "
                . "UNION DISTINCT "
                . "SELECT * "
                . "FROM `users` "
                . "INNER JOIN `friend` ON (`username` = `user_acc`) "
                . "WHERE (`user_req` = ? AND `status` = '1')");
Se aggiungo un ORDER BY, in questo modo, in funziona più...
Codice:
$stmt = $db->prepare("(SELECT * "
                . "FROM `users` "
                . "INNER JOIN `friend` ON (`username` = `user_req`) "
                . "WHERE (`user_acc` = ? AND `status` = '1') "
                . "UNION DISTINCT "
                . "SELECT * "
                . "FROM `users` "
                . "INNER JOIN `friend` ON (`username` = `user_acc`) "
                . "WHERE (`user_req` = ? AND `status` = '1')) ORDER BY `username`");
E' indifferente come viene ordinato l'array (a livello sql o php), l'importante è che sia ordinato (almeno) secondo l'username.

Come posso fare?
stefano861 è offline   Rispondi citando il messaggio o parte di esso
Old 09-02-2014, 17:00   #2
stefano861
Member
 
Iscritto dal: Nov 2013
Messaggi: 62
Consigli?
stefano861 è offline   Rispondi citando il messaggio o parte di esso
Old 09-02-2014, 19:35   #3
GByTe87
Senior Member
 
L'Avatar di GByTe87
 
Iscritto dal: Mar 2007
Città: Milano Beach
Messaggi: 1696
Premesso che non conosco assolutamente PHP e che quello non mi sembra un array multidimensionale, ti direi di usare usort
__________________
~ Cthulhu: MacBookPro 13.3" ~ Azathoth: D510MO
GByTe87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Il dodicesimo lancio del razzo spaziale ...
Blue Origin sta assemblando il secondo l...
Meta moltiplica gli investimenti in data...
Addio riflessi fastidiosi? Samsung prese...
PlayStation 5, doccia fredda da Sony: i ...
Super Meat Boy 3D: annunciata la data d'...
XT View Matrix, il mid-tower Phanteks ch...
David Sacks lascia il ruolo di 'Crypto C...
LG All Stars 2026: quando l'installatore...
Addio ad Anna's Archive? Ecco la mossa l...
Addio al Mac Pro, Apple mette fine a un ...
Panasonic a MCE 2026: la rivoluzione sil...
Netflix alza la posta: il piano Premium ...
Nimbus Innovation Awards – Cloud Edition...
Wikipedia vieta i contenuti generati dal...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 22:52.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v