domingo, 3 de agosto de 2014

Las funciones en PHP - 2 de 2



7. Funciones de la función de gestión
  • La función func_get_arg(int $numero) devuelve un elemento de la lista de argumentos de entrada, es decir, los argumentos que se han pasado con $numero, como el número del argumento.

Por ejemplo:

<?php
function muestra_argumentos($argumento1,$argumento2) {
echo "El valor del primer argumento es:".func_get_arg(0);
echo "El valor del segundo argumento es:".func_get_arg(1);
}
muestra_argumentos("Hola","Roberto");
?>

Da como resultado:

El valor del primer argumento es:Hola
El valor del segundo argumento es:Roberto

  • La función func_num_args() devuelve el número de argumentos de entrada, es decir, los argumentos que se han pasado.

Por ejemplo:

<?php
function muestra_numero_argumentos($argumento1,$argumento2) {
echo "El número de argumentos es:".func_num_args();
}
muestra_numero_argumentos("Hola","Roberto");
?>

Da como resultado:

El número de argumentos es: 2

  • La función func_get_args() devuelve los argumentos que pasan como argumentos en forma tabla.

Por ejemplo:

<?php
function muestra_argumentos($argumento1,$argumento2) {
$num_args = func_num_args();
$arg_lista = func_get_args();
for ($i = 0; $i < $num_args; $i++) {
echo "El argumento $i es: " . $arg_lista[$i] . "<br />\n";
}
}
muestra_argumentos("Hola","Roberto");
?>

Da como resultado:

El argumento 0 es:Hola
El argumento 1 es:Roberto

  • La función function_exists() devuelve un booleano e indica si una función existe o no.

Por ejemplo:

<?php
function muestra_numero_argumentos($argumento1,$argumento2) {
echo "El número de argumentos es:".func_num_args();
}
if (function_exists(’muestra_numero_argumentos’)) {
echo "La función existe.";
} else {
echo "La función no existe.";
}
?>

Da como resultado:

La función existe.

Puede crear su función de manera dinámica con ayuda de la función create_function(). Para más información, visite la página Web: www.php.net/manual/es/function.create-function.php


8. Recursividad

La recursividad significa que una función se llama a sí misma. Es muy útil para navegar en una arborescencia, sobre todo si se desconoce de antemano el número de ramas.

Por ejemplo:

<?php
function funcion_recursiva($n)
{
$n++; //incrementa n de 1 en 1
echo "$n,";
if($n < 10){ // si n es inferior a 10, recurre a la función
funcion_recursiva($n);
}
}
funcion_recursiva(0); // muestra los números de 1 a 10
?>

Da como resultado:

1,2,3,4,5,6,7,8,9,10,

En la condición if($n < 10), la función se llama a sí misma, y se puede llamar hasta diez veces en total. De hecho, si no hubiera una condición ($n < 10), el bucle sería infinito.

A continuación veremos el código que muestra los valores de las tablas tridimensionales:

<?php
function mostrar_tabla($tabla,$titulo="",$nivel=0) {
// Parámetros
// - $tabla = tabla que debe mostrar el contenido
// - $titulo = título que hay que mostrar encima del contenido
// - $nivel = nivel de visualización
if ($titulo != "") { // Si hay un título, mostrarlo.
echo "<br /><b>".$titulo."</b><br />";
}
// Comprobar si hay datos.
if (isset($tabla)) { // Hay datos
// Navegar por la tabla que se pasa como argumento.
foreach ($tabla as $clave => $valor) {
// mostrar la clave (con indentation función
// del nivel).
// htmlentities() es la función que convierte los
//caracteres especiales HTML
echo str_pad(’’,12*$nivel, ’&nbsp;’).
htmlentities($clave).’ = ’;
// mostrar el valor
if (is_array($valor)) { // comprueba si es una tabla
echo ’<br />’;
// Llama recursivamente a mostrar_tabla para
// mostrar la tabla en cuestión
mostrar_tabla($valor,’’,$nivel+1);
} else { // es un valor escalonado
// mostrar el valor.
echo htmlentities($valor).’<br />’;
}
}
} else { // no hay datos
echo ’<br />’;
}
}
// Declaración de las tablas.
$tab_caracteristica_ESTEFANIA = array("nombre" => "PABLO",
"profesión" => "ministro","edad" => 50);
$tab_caracteristica_LUNA= array("nombre" => "ROBERTO",
"profesión" => "agricultor","edad" => 45);
$tab_persona[’ESTEFANIA’] = $tab_caracteristica_ESTEFANIA;
$tab_persona[’LUNA’] = $tab_caracteristica_LUNA;
// Mostrar una tabla con dos dimensiones (Apellido/
Características).
mostrar_tabla($tab_persona,’Apellido/Características’);
?>

Da como resultado:

Apellido/Características
ESTEFANIA =
nombre = PABLO
profesión = ministro
edad = 50
LUNA =
nombre = ROBERTO
profesión = agricultor
edad = 45

La principal ventaja de esta función recursiva es que, si tiene una tabla de tres, cuatro o más dimensiones, no es preciso cambiar el código, porque no depende del número de dimensiones.


9. Funciones predefinidas en PHP

Hay alrededor de 4500 funciones predefínidas en PHP. Las puede consultar en la siguiente página Web, donde están agrupadas por temas: http://www.php.net/manual/es/funcref.php

Ya ha visto algunas de ellas en secciones anteriores, como substr() o implode(). Ahora vamos a ver algunas funciones complementarias que son también muy útiles.

  • a. Generar un número aleatorio

La función rand() permite generar un valor aleatorio comprendido entre 0 y 32768. Puede pasar como argumento de entrada unos límites mínimo y máximo.

Por ejemplo:

<?php
echo rand()."<br />";
echo rand(10,20)."<br />";
?>

Da como resultado:

24751
13

  • b. Redondear un número decimal

La función round($numero_decimal) permite redondear un número decimal.

Por ejemplo:

<?php
echo round(3.141592);
?>

Da como resultado:

3

Esta función acepta la precisión como argumento complementario, es decir, el número de dígitos que quiera poner después de la coma.

Por ejemplo:

<?php
echo round(3.141592); //2 dígitos después de la coma
?>

Da como resultado:

3.14

Otro ejemplo:

<?php
echo round(3.779592); //2 dígitos después de la coma
?>

Da como resultado:

3.78

Es decir se ha redondeado el número.

  • c. Tomar el valor absoluto de un número

La función abs($nombre) permite recuperar el valor absoluto de un número.

Por ejemplo:

<?php
echo abs(-5.2);
?>

Da como resultado:

5.2

Esta función acepta como parámetro una cadena de caracteres.

Por ejemplo:

<?php
echo abs("68");
?>

Da como resultado:

68

  • d. Crear un identificador único

La función uniqid() permite generar de forma aleatoria un valor de trece caracteres, de tal manera que este valor sea único. A veces es muy útil para generar identificadores únicos que se van a insertar en la base de datos.

Por ejemplo:

<?php
echo "Id único:".uniqid().", ";
echo "Id único:".uniqid().", ";
echo "Id único:".uniqid();
?>

Da como resultado:

Id único:4df0d26502f82, Id único:4df0d26502f86, Id único:4df0d26502f87

  • e. Mostrar información de PHP

La función phpversion() permite mostrar la versión actual de PHP.

Por ejemplo:

<?php
echo phpversión();
?>

Da como resultado:

5.3.3

La función phpinfo() permite mostrar información de la configuración de PHP que ha instalado en su servidor, como las variables de entorno o la configuración de Apache. Esta información se almacena en el archivo php.ini, cuya utilización se explicará en el siguiente capítulo.

Por ejemplo:

<?php
phpinfo();
?>

La función ini_get_all() devuelve toda la información del archivo PHP.ini, pero en forma de tabla.

Para terminar, la función get_loaded_extensions() devuelve una tabla que contiene todas las extensiones que se han descargado. Lo veremos en el capítulo Configuración.

  • f. Enviar un e-mail

La función mail() permite enviar un e-mail. Es una función básica que no debe utilizar si quiere enviar un gran volumen de mensajes de correo electrónico, porque con cada envío cierra y vuelve a abrir una conexión al servidor. Hay otras funciones más prácticas y eficaces, como PEAR o PHPMailer. Sin embargo, el estudio de esta función permite ver las bases de envío de un e-mail, que son comunes a todas las funciones.

Los parámetros de la función son:
  • $to: los destinatarios del e-mail
  • $subject: asunto del e-mail
  • $message: contenido del e-mail
  • $headers: parámetro opcional que contiene el encabezado del e-mail

El encabezado permite definir el remitente del e-mail (From), el tipo MIME, la codificación y otros parámetros. Puede encontrar más información en el siguiente enlace:


El remitente (From), la dirección SMTP y el número de puerto SMTP se definen en el archivo PHP.ini, al que puede acceder desde el menú Configuración - PHP.

Por ejemplo:

<?php
$to = ’persona@ejemplo.com’;
$subject = ’Asunto’;
$message = ’¡Hola a todos!’;
$headers = ’From: webmaster@misitio.com’."\r\n"
’Reply-To: webmaster@misitio.com’."\r\n"
’MIME-Version: 1.0’."\r\n";
mail($to, $subject, $message, $headers);
?>

La función mail() no se puede autentificar y por tanto no funciona en modo local si, por ejemplo, utiliza el servidor SMTP de Gmail. Deberá utilizar la librería Mail-1.2.0 de PEAR que está disponible en la siguiente dirección: http://pear.php.net/package/Mail/download/1.2.0/

El e-mail que ha envíado está en formato texto. Para enviarlo en formato HTML, debe declarar este formato en el encabezado (header):

$headers = ’From: webmaster@misitio.com’."\r\n"
’Reply-To: webmaster@misitio.com’."\r\n"
’MIME-Version: 1.0’."\r\n"
’Content-type: text/html; charset=iso-8859-1’."\r\n";



Espero haber ayudado en algo. Hasta la próxima oportunidad!







No hay comentarios:

Publicar un comentario en la entrada