Foro de elhacker.net

Programación => PHP => Mensaje iniciado por: Servia en 5 Marzo 2011, 12:45 pm



Título: Duda con arrays dentro de arrays
Publicado por: Servia en 5 Marzo 2011, 12:45 pm
Pongamos que tengo:

Código
  1. while($info=mysql_fetch_array($resultado_query)){
  2.  
  3. $datos[$info['id']]=$info['nombre'];
  4. }

Si ahora quiero que este array [array ( id -> nombre)] lleve otro campo, como debería hacerlo?


Código
  1. while($info=mysql_fetch_array($resultado_query)){
  2.  
  3. $datos[$info['id']]=$info['nombre'];
  4. $datos[$info['id']]['apellido']=$info['apellido'];
  5. }

Esto funcionaría?
Si hiciese

Código
  1. foreach($datos AS $k => $v)
  2. {
  3. $parseo[$i]["id"]=$k;
  4. $parseo[$i]["nombre"]=$v;
  5. $parseo[$i]["apellido"]=$v['apellido'];
  6.  
  7.  
Sería correcto? O tendría que cambiar el foreach entero? Hay alguna posibilidad de evitar cambiar el foreach?


Título: Re: Duda con arrays dentro de arrays
Publicado por: ~ Yoya ~ en 5 Marzo 2011, 15:21 pm
No entiendo muy bien lo que tratas de hacer, cual es el objetivo de lo que tratas de hacer¿?
Así entenderé lo que tratas de hacer.


Título: Re: Duda con arrays dentro de arrays
Publicado por: Servia en 6 Marzo 2011, 09:50 am
No entiendo muy bien lo que tratas de hacer, cual es el objetivo de lo que tratas de hacer¿?
Así entenderé lo que tratas de hacer.

Quiero tener un array con 3 datos, id, nombre y apellido y quiero saber como meter el tercero y sacarlo en los casos expresados :)


Título: Re: Duda con arrays dentro de arrays
Publicado por: Stoya en 6 Marzo 2011, 12:23 pm
Arrays dentro de arrays dentro de arrays... Origen.

Lo que tu quieres tener un array de tuplas con tres datos cada una, aunque para manejar las tuplas es mejor usar los arrays. Aunque igualmente no son arrays, son maps o diccionarios, lo que pasa es que para php todo es lo mismo.

Si no sabes si funciona un código o no, no pongas tonterías en un foro, le das a ejecutar y ves si funciona, en realidad, ves que no funciona. En realidad sería:

Código
  1. while($info=mysql_fetch_array($resultado_query)){
  2.    $datos[$info['id']]['nombre']=$info['nombre'];
  3.    $datos[$info['id']]['apellido']=$info['apellido'];
  4. }

Tal vez te parezca como que tienes un nodo en blanco o algo así si tienes conocimiento previo de otras cosas, pero no es el caso, php no va así.


Título: Re: Duda con arrays dentro de arrays
Publicado por: ~ Yoya ~ en 6 Marzo 2011, 12:58 pm
Aunque igualmente no son arrays, son maps o diccionarios, lo que pasa es que para php todo es lo mismo.

xDDDDD.

En otros lenguajes también son llamados hash, pero en este caso son Array bidimensional xD. También en algunos lenguajes se le llaman así xD.

Nose cual seria el objetivo de @Servia, pero no esta optimizando.


Título: Re: Duda con arrays dentro de arrays
Publicado por: Stoya en 6 Marzo 2011, 13:26 pm
En otros lenguajes también son llamados hash, pero en este caso son Array bidimensional xD. También en algunos lenguajes se le llaman así xD.
El caso es que el índice del array no es un número del 0 a longitud del array-1, por tanto no es exactamente un array. Esto es especialmente importante porque quiere guardar tuplas de 3 elementos, pero como ves, uno pasa a ser el identificador o clave.

Nose cual seria el objetivo de @Servia, pero no esta optimizando.
Con que sea capaz de escribir algo que el intérprete de php entienda yo ya le consideraría afortunado, todavía le queda mucho por aprender de php como para aprender de metodología de la programación (que es por donde irían las optimizaciones, al menos inicialmente).


Título: Re: Duda con arrays dentro de arrays
Publicado por: Servia en 7 Marzo 2011, 10:13 am
Y entonces el foreach como debería ir? O ya está bien como lo he puesto ?


Título: Re: Duda con arrays dentro de arrays
Publicado por: cassiani en 7 Marzo 2011, 16:41 pm
Servia, haber si es esto lo que buscas, te dejo un ejemplo:

Teniendo una tabla con los siguientes datos:
Código:
+----------+---------+--------+
| idtabla1 | campo1  | campo2 |
+----------+---------+--------+
|        1 | Juan    | Perez  |
|        2 | Maria   | Lopez  |
|        3 | Luis    | Martin |
|        4 | mariana | ruiz   |
|        5 | karen   | martin |
|        6 | kim     | gomez  |
+----------+---------+--------+

Asignamos los datos a un array:
Código
  1. while ($row = mysql_fetch_array($result))
  2. $sDatos[]= array
  3. (
  4. 'id' => $row['idtabla1'],
  5. 'campo1' => $row['campo1'],
  6. 'campo2' => $row['campo2']
  7. );

Luego mostramos para comprobar:
Código:
echo "<pre>"; print_r($sDatos); echo "</pre>";

se verá así:
Código:
Array
(
    [0] => Array
        (
            [id] => 1
            [campo1] => Juan
            [campo2] => Perez
        )

    [1] => Array
        (
            [id] => 2
            [campo1] => Maria
            [campo2] => Lopez
        )

    [2] => Array
        (
            [id] => 3
            [campo1] => Luis
            [campo2] => Martin
        )

    [3] => Array
        (
            [id] => 4
            [campo1] => mariana
            [campo2] => ruiz
        )

    [4] => Array
        (
            [id] => 5
            [campo1] => karen
            [campo2] => martin
        )

    [5] => Array
        (
            [id] => 6
            [campo1] => kim
            [campo2] => gomez
        )

)

Es una matriz o array bidimencional, accedes a los datos colocando
Código:
$sDatos[aqui el id][aqui la etiqueta del dato]

ejemplo:
Código:
echo $sDatos[4]['campo1'];

Imprime:
Código:
karen

espero te sirva, saludos!


Título: Re: Duda con arrays dentro de arrays
Publicado por: Stoya en 7 Marzo 2011, 17:29 pm
Y con lo que te dice cassiani ya lo tienes como querías dejarlo después del for-each, que en mi opinión es peor que como estaba antes. No se tú, pero si yo pongo:
Código:
echo $sDatos[4]['campo1'];

Quiero que imprima:
Código:
mariana


Título: Re: Duda con arrays dentro de arrays
Publicado por: cassiani en 7 Marzo 2011, 19:13 pm
No se tú, pero si yo pongo:
Código:
echo $sDatos[4]['campo1'];

Quiero que imprima:
Código:
mariana

en realidad no, porque la matriz comienza desde 0 y no así la columna Id de la tabla. de todas maneras puedes usar un contador que comience desde 1 o usar el mismo Id de cada registro para agregar elementos al array:

Código
  1.  
  2. while ($row = mysql_fetch_array($result))
  3. $sDatos[$row['idtabla1']]= array
  4. (
  5. 'campo1' => $row['campo1'],
  6. 'campo2' => $row['campo2']
  7. );
  8.  

y ahí al colocar:
Código:
echo $sDatos[4]['campo1'];

si imprimirá:
Código:
mariana


Título: Re: Duda con arrays dentro de arrays
Publicado por: Stoya en 8 Marzo 2011, 09:08 am
Ya lo sé, pero has puesto id dos veces y con distinto significado, revisa tu post si quieres.

Eso desde un punto de vista de metodología de la programación está muy mal, completamente inaceptable.


Título: Re: Duda con arrays dentro de arrays
Publicado por: Servia en 10 Marzo 2011, 09:04 am
Muchas gracias a ambos! Veo que la optimización es muy importante aquí ^^

Una función (soy pesado eh) la cual limpiase el array $_POST cada vez que no lo detectará como vacío, cargaría mucho la página?

El proceso de limpieza como strip_tags y mysql_real_escape_string es mejor que los ponga dentro de una función y la llame dentro del foreach o es mejor ponerlo todo directamente?
Código
  1. if(isset($_POST)){
  2. foreach ($_POST as $p){
  3. strip..
  4. mysql_real....
  5. }}

Código
  1. if(isset($_POST)){
  2. function clean(){
  3. }
  4. foreach ($_POST as $p){
  5. $p=clean($p);
  6. }}