Diferencia entre revisiones de «Usuario:ManuelRomero/php/arrays/concepto»
De WikiEducator
< Usuario:ManuelRomero | php
| (17 revisiones intermedias por el mismo usuario no mostrado) | |||
| Línea 1: | Línea 1: | ||
| + | |||
| + | <!--__NOEDITSECTION__--> | ||
| + | |||
| + | {|cellpadding="5" cellspacing="6" style="width:100%;background:#DFFFFF; border-style:solid; border-width:2px; border-color:#0066FF;" | ||
| + | | width="100%" valign="top" style="padding: 0; margin:0px;" | | ||
| + | {|cellpadding="5" cellspacing="6" style="width:100%;background:#DFFFFF; border-style:solid; border-width:1px; border-color:#0066FF;" | ||
| + | | width="100%" valign="top" style="padding: 0; margin:0px;" | | ||
| + | <span style="background:#FFFF99"> | ||
| + | </span> | ||
| + | [[Imagen:DWES_TituloTema3_arryas|center]] | ||
| + | |} | ||
__NOTOC__ | __NOTOC__ | ||
{{#widget:Slides}} | {{#widget:Slides}} | ||
| − | {{:Usuario:ManuelRomero/php/arrays/nav}} | + | <!--{{:Usuario:ManuelRomero/php/arrays/nav}}--> |
<div class="slides layout-regular template-default"> | <div class="slides layout-regular template-default"> | ||
<div class="slide"> | <div class="slide"> | ||
| Línea 14: | Línea 25: | ||
{{Definicion|Un array es un tipo de datos que nos permite almacenar varios valores. }} | {{Definicion|Un array es un tipo de datos que nos permite almacenar varios valores. }} | ||
*Cada miembro del array se almacena en una posición a la que se hace referencia utilizando un valor clave. | *Cada miembro del array se almacena en una posición a la que se hace referencia utilizando un valor clave. | ||
| − | [Archivo: | + | [[Archivo:arrayPHP.png]] |
</div> | </div> | ||
| − | <!-- | + | <!--2--> |
<div class="slide"> | <div class="slide"> | ||
| − | * | + | *Depediendo del valor de la posición podemos clasificar los arraiis de dos tipos |
| + | #'''''Indexado'''''. Cada valor es un entero que indica su posición, empezando por cero. | ||
| + | #'''''Asociativo'''''. El valor de cada posición tiene un significado diferente a la posición que ocupa y puede ser de cualquier tipo | ||
<source lang=php> | <source lang=php> | ||
// array numérico | // array numérico | ||
| Línea 27: | Línea 40: | ||
$modulos2 = array("PR" => "Programación", "BD" => "Bases de datos", ..., "DWES" => "Desarrollo web en entorno servidor"); | $modulos2 = array("PR" => "Programación", "BD" => "Bases de datos", ..., "DWES" => "Desarrollo web en entorno servidor"); | ||
</source> | </source> | ||
| − | [Archivo: | + | </div> |
| − | + | ||
| − | + | <!--1--> | |
| − | + | <div class="slide"> | |
| + | ;Arrays asociativos Vs indexados | ||
| + | [[Archivo:array2PHP.png|center]] | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ===Array numéricos o indexados=== | ||
| + | *Clasificación en función de la clave que llevan | ||
| + | #Clave numérica posicional : La clave especifica la posicion de cada elemento | ||
| + | #Clave con valor: La clave tiene un significado por sí mismo y tiene '''asociado''' un valor | ||
| + | ;Arrays indexados | ||
:En los arrays numéricos empezamos por 0 | :En los arrays numéricos empezamos por 0 | ||
:En funcion del tipo de índices que tenga puede ser unidimensional o multidimensional (varios índices). | :En funcion del tipo de índices que tenga puede ser unidimensional o multidimensional (varios índices). | ||
| − | ===Crear un array=== | + | </div> |
| − | *Podemos usar el operador array(); | + | |
| − | *A partir de la versión 5.3 se puede directamente usar el operador [] | + | <!--2--> |
| + | <div class="slide"> | ||
| + | ===Trabajar con un array=== | ||
| + | *A la hora de trabajar con arrays, hay que saber operar con ellos | ||
| + | #Crear o definir un array | ||
| + | #Asignar, agregar valores al array | ||
| + | #Leer elementos del array | ||
| + | #Borrar elementos del array | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ====Crear un array==== | ||
| + | *Podemos usar el operador '''''array();''''' | ||
| + | *A partir de la versión 5.3 se puede directamente usar el operador '''''[]''''' | ||
*Vemos como crear un array | *Vemos como crear un array | ||
| + | *En php no hay que especificar ni índice ni lógicamente tipo | ||
| + | *El array como hemos comentado va a ser un conjunto de elementos, cada tipo de cada elemento dependerá del valor que contenga en cada momento , y por supuesto puede ser modificado (tanto el valor como el tipo). | ||
| + | </div> | ||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ;Crear un array | ||
| + | <source lang=php> | ||
| + | /* | ||
| + | Creamos una variable array llamada miArray vacía | ||
| + | Dos formas equivalentes | ||
| + | */ | ||
| + | $miArray = array(); | ||
| + | $miArray = []; | ||
| + | /* | ||
| + | Creamos un array indexado de ciudades | ||
| + | */ | ||
| + | $miArray = array("burgos","zaragoza","huesca", "teruel","soria"); | ||
| + | $miArray = ["burgos","zaragoza","huesca", "teruel","soria"]; | ||
| + | |||
| + | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ====Escribir en un array==== | ||
| + | *Simplemento hay que asignar un valor a una posición del array | ||
| + | *Al ser indexado, si no se pone valor en índice se pondrá una unidad más al último valor asignado | ||
| + | *Si pongo un valor superior al número de índices, el siguiente elemento estará en una posición mas | ||
<source lang=php> | <source lang=php> | ||
$notas =[]; | $notas =[]; | ||
| − | + | $notas[]=10; | |
| − | $notas = | + | $notas[]=7; |
| + | $notas[5]= 8; | ||
| + | $notas [] =9; | ||
| + | $notas [] =6; | ||
</source> | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ;Escribir en un array | ||
| + | *Podemos ver gráficamente como queda el array | ||
| + | [[Archivo:arrayNotas.png]] | ||
| + | *En realidad las posiciones no especificadas no existen | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | [[Archivo:arrayNotas2.png]] | ||
| + | *Vemos como la posición 2,3 y 4 no van a existir con valores en el array | ||
| + | *Las puedo usar expícitamente | ||
| + | <source lang=php> | ||
| + | $notas[2]= 8; | ||
</source> | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ===Leer un array=== | ||
| + | *Hemos de diferenciar entre dos conceptos | ||
| + | ;Leer un elemento de un array | ||
| + | Simplemente accedemos a su posición por el índice | ||
| + | <source lang=php> | ||
| + | echo "la nota primera es $notas[0]"; | ||
| + | echo "la nota última es $nota[7]"; | ||
| + | </source> | ||
| + | |||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ;Recorrer un array | ||
| + | *Tenemos difernetes modos de recorre un array, pues el entorno nos ofrece diferentes modos | ||
| + | count($nombreArray); | ||
| + | *Es una función que nos dice cuantos elementos tiene un array que le pasamos como argumentos | ||
| + | *Ejemplo | ||
| + | <source lang=php> | ||
| + | $ciudades = ["burgos","zaragoza","huesca", "teruel","soria"]; | ||
| + | $numeroCiudadades = count($ciudades); | ||
| + | echo "El array tienen $numeroCiudades ciudades<br/>"; | ||
| + | //mostrará 5 ciudades | ||
| + | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ;Recorrer un array | ||
| + | *Vamos a usarla con un ejemplo | ||
| + | {{MRM_Actividad| | ||
| + | *Creamos 10 notas aleatorias, y posteriormente las visualizamos | ||
| + | *Sacamos la máxima la mínima y la media}} | ||
| + | <source lang=php> | ||
| + | <?php | ||
| + | //Creo la variable array de notas | ||
| + | $notas=[]; | ||
| + | |||
| + | |||
| + | //Relleno el array con 10 notas | ||
| + | //$notas = array_fill(0, 10,rand(1,10)); | ||
| + | for ($a=0;$a<10;$a++) | ||
| + | $notas[$a]=rand(1,10); | ||
| + | |||
| + | |||
| + | $min = $notas[0]; | ||
| + | $max = $notas[0]; | ||
| + | for ($a=0;$a<10;$a++){ | ||
| + | echo "Valor de la posición $a = ". $notas[$a]."<br />"; | ||
| + | $total+=$notas[$a]; | ||
| + | $min = $notas[$a]<$min ? $notas[$a] : $min; | ||
| + | $max = $notas[$a]>$max ? $notas[$a] : $max; | ||
| + | } | ||
| + | |||
| + | |||
| + | echo "Valor de la nota media ".($total/10)."<br />"; | ||
| + | echo "Valor minimo".$min."<br />"; | ||
| + | echo "Valor maximo ".$max."<br />"; | ||
| + | </source> | ||
| + | |||
| + | |||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ;Recorrer un array | ||
| + | *Vemos que si todos los elementos están seguidos este funciona bien, pero si no es así no funcioría correctamete | ||
| + | {{Pregunta|¿Por qué no conviene usar la función count}} | ||
<source lang=php> | <source lang=php> | ||
$capitales = array(); | $capitales = array(); | ||
$capital ["españa"=>"madrid", "italia"=>"roma","Alemania"=>"Berlin"]; | $capital ["españa"=>"madrid", "italia"=>"roma","Alemania"=>"Berlin"]; | ||
</source> | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ;Recorrer un array | ||
*Es lo mismo que hacer | *Es lo mismo que hacer | ||
<source lang=php> | <source lang=php> | ||
| Línea 58: | Línea 221: | ||
$capitales["Alemania"]="Berlin"; | $capitales["Alemania"]="Berlin"; | ||
</source> | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
*Existen muchas funciones asociadas a los arrays | *Existen muchas funciones asociadas a los arrays | ||
| − | + | count($array) | |
| + | :me da el número de elementos. | ||
{{Tarea| | {{Tarea| | ||
Define un array de 5 ciudades y recorrelo con un bucle for usando count() | Define un array de 5 ciudades y recorrelo con un bucle for usando count() | ||
}} | }} | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
<source lang=php> | <source lang=php> | ||
<?php | <?php | ||
| Línea 80: | Línea 252: | ||
?> | ?> | ||
</source> | </source> | ||
| + | </div> | ||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
===Ver el contenido de un array=== | ===Ver el contenido de un array=== | ||
*Podemos usar la función ya conocida '''''var_dump()''''' | *Podemos usar la función ya conocida '''''var_dump()''''' | ||
| Línea 91: | Línea 266: | ||
*Ordenar sort() | *Ordenar sort() | ||
*Aquí tenemos un listado de todas las funciones, hay muchas muchas http://es1.php.net/manual/en/ref.array.php | *Aquí tenemos un listado de todas las funciones, hay muchas muchas http://es1.php.net/manual/en/ref.array.php | ||
| + | </div> | ||
| − | + | <!--2--> | |
| − | + | <div class="slide"> | |
*Para hacer referencia a los elementos almacenados en un array, tienes que utilizar el valor clave entre corchetes: | *Para hacer referencia a los elementos almacenados en un array, tienes que utilizar el valor clave entre corchetes: | ||
<source lang=php> | <source lang=php> | ||
| Línea 99: | Línea 275: | ||
$modulos2 ["DWES"] | $modulos2 ["DWES"] | ||
</source> | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
*Es interesante recordar que en PHP puedes crear también arrays de varias dimensiones almacenando otro array en cada uno de los elementos de un array. | *Es interesante recordar que en PHP puedes crear también arrays de varias dimensiones almacenando otro array en cada uno de los elementos de un array. | ||
<source lang=php> | <source lang=php> | ||
| Línea 107: | Línea 287: | ||
); | ); | ||
</source> | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
*Para hacer referencia a los elementos almacenados en un array multidimensional, debes indicar las claves para cada una de las dimensiones: | *Para hacer referencia a los elementos almacenados en un array multidimensional, debes indicar las claves para cada una de las dimensiones: | ||
<source lang=php> | <source lang=php> | ||
| Línea 114: | Línea 298: | ||
*Ni siquiera es necesario indicar que una variable concreta es de tipo array. | *Ni siquiera es necesario indicar que una variable concreta es de tipo array. | ||
*Como ya hemos visto, simplemente puedes comenzar a asignarle valores: | *Como ya hemos visto, simplemente puedes comenzar a asignarle valores: | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
<source lang=php> | <source lang=php> | ||
// array numérico | // array numérico | ||
| Línea 126: | Línea 314: | ||
$modulos2 ["DWES"] = "Desarrollo web en entorno servidor"; | $modulos2 ["DWES"] = "Desarrollo web en entorno servidor"; | ||
</source> | </source> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
*En PHP tampoco es necesario que especifiques el valor de la clave. | *En PHP tampoco es necesario que especifiques el valor de la clave. | ||
*Al omitirla el array se irá llenando a partir de la última clave numérica existente, o de la posición 0 si no existe ninguna: | *Al omitirla el array se irá llenando a partir de la última clave numérica existente, o de la posición 0 si no existe ninguna: | ||
| Línea 134: | Línea 326: | ||
$modulos1 [ ] = "Desarrollo web en entorno servidor"; | $modulos1 [ ] = "Desarrollo web en entorno servidor"; | ||
</source> | </source> | ||
| + | </div> | ||
<div class="slide"> | <div class="slide"> | ||
| − | |||
| − | |||
| − | |||
| − | |||
{{Tarea| | {{Tarea| | ||
*Generar un array de 10 posiciones de valores enteros entre 1 y 100. | *Generar un array de 10 posiciones de valores enteros entre 1 y 100. | ||
| Línea 144: | Línea 333: | ||
*Mostrar los resultados por pantalla. | *Mostrar los resultados por pantalla. | ||
}} | }} | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | <!-- | ||
<source lang=php> | <source lang=php> | ||
<?php | <?php | ||
| Línea 173: | Línea 367: | ||
</source> | </source> | ||
| + | --> | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
{{Tarea| | {{Tarea| | ||
*Implementar una función que busca si un determinado valor aparece en una matriz. | *Implementar una función que busca si un determinado valor aparece en una matriz. | ||
| Línea 182: | Línea 381: | ||
#Mostrar los resultados por pantalla. | #Mostrar los resultados por pantalla. | ||
}} | }} | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
{{Tarea| | {{Tarea| | ||
'''''Random Images''''' | '''''Random Images''''' | ||
| Línea 188: | Línea 391: | ||
**La página debe mostrar, aleatoriamente, 3 imágenes (puedes usar como alternativa la función shuffle ($imagenes) la cuál desordena el vector), o usar un rand para obtener indices aleatorios. | **La página debe mostrar, aleatoriamente, 3 imágenes (puedes usar como alternativa la función shuffle ($imagenes) la cuál desordena el vector), o usar un rand para obtener indices aleatorios. | ||
**Cada 5 segundos ha de refrescarse la página para ir mostrando imágenes distintas (podéis usar, por | **Cada 5 segundos ha de refrescarse la página para ir mostrando imágenes distintas (podéis usar, por | ||
| − | ejemplo, este trozo de código HTML y añadirlo en el <HEAD> de la página | + | ejemplo, este trozo de código HTML y añadirlo en el <HEAD> de la página |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
}} | }} | ||
| − | <source lang= | + | <source lang=html5> |
| − | + | <head> | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
<meta charset="UTF-8"/> | <meta charset="UTF-8"/> | ||
<meta http-equiv="refresh" content="5" url="index.php"/> | <meta http-equiv="refresh" content="5" url="index.php"/> | ||
<title></title> | <title></title> | ||
</head> | </head> | ||
| − | + | </div> | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | </ | + | |
</source> | </source> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
===Variables globales Vs superglobales=== | ===Variables globales Vs superglobales=== | ||
| Línea 236: | Línea 411: | ||
*El desarrollador tiene acceso a dichas variables en cualquier momento del script. | *El desarrollador tiene acceso a dichas variables en cualquier momento del script. | ||
*El sistema se encarga de tenerlas actualizadas, con el valor correspondiente | *El sistema se encarga de tenerlas actualizadas, con el valor correspondiente | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | ;Superglobales | ||
*PHP incluye unas Son variables internas predefinidas que pueden usarse desde cualquier ámbito, por lo que reciben el nombre de variables superglobales. | *PHP incluye unas Son variables internas predefinidas que pueden usarse desde cualquier ámbito, por lo que reciben el nombre de variables superglobales. | ||
*No es necesario que uses global para acceder a ellas. | *No es necesario que uses global para acceder a ellas. | ||
| Línea 242: | Línea 422: | ||
*Posteriormente veremos cómo se utilizan los arrays). | *Posteriormente veremos cómo se utilizan los arrays). | ||
*Aquí puedes acceder a las variables [http://es.php.net/manual/es/language.variables.superglobals.php superglobales] disponibles en PHP se pueden ver son las siguientes: | *Aquí puedes acceder a las variables [http://es.php.net/manual/es/language.variables.superglobals.php superglobales] disponibles en PHP se pueden ver son las siguientes: | ||
| − | + | </div> | |
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
| + | |||
| + | ;Superglobales (Algunas principales) | ||
#$GLOBALS Hace referencia a todas las variables disponibles en el ámbito global | #$GLOBALS Hace referencia a todas las variables disponibles en el ámbito global | ||
#$_SERVER Información del entorno del servidor y de ejecución | #$_SERVER Información del entorno del servidor y de ejecución | ||
| Línea 252: | Línea 437: | ||
#$_REQUEST Variables HTTP REQUEST. Un array asociativo que por defecto contiene el contenido de $_GET, $_POST y $_COOKIE. | #$_REQUEST Variables HTTP REQUEST. Un array asociativo que por defecto contiene el contenido de $_GET, $_POST y $_COOKIE. | ||
#$_ENV | #$_ENV | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
*Analizaremos una de ellas | *Analizaremos una de ellas | ||
;$_SERVER. | ;$_SERVER. | ||
| Línea 262: | Línea 451: | ||
#$_SERVER['REMOTE_ADDR']:dirección IP desde la que el usuario está viendo la página. | #$_SERVER['REMOTE_ADDR']:dirección IP desde la que el usuario está viendo la página. | ||
#$_SERVER['REQUEST_METHOD']:método utilizado para acceder a la página ('GET', 'HEAD', 'POST' o 'PUT') | #$_SERVER['REQUEST_METHOD']:método utilizado para acceder a la página ('GET', 'HEAD', 'POST' o 'PUT') | ||
| + | </div> | ||
| + | |||
| + | <!--2--> | ||
| + | <div class="slide"> | ||
{{Actividad| Haz un script que nos de la información de las variables vistas anteriormente}} | {{Actividad| Haz un script que nos de la información de las variables vistas anteriormente}} | ||
| + | <!-- | ||
<source lang=php> | <source lang=php> | ||
<?php | <?php | ||
| Línea 272: | Línea 466: | ||
?> | ?> | ||
</source> | </source> | ||
| + | --> | ||
| + | </div> | ||
| + | |} | ||
Última revisión de 11:23 25 oct 2016
|



