Funciones en PHP
Para definir funciones disponemos de la instrucción function
Después de esta palabra reservada se coloca el nombre de la función seguido de una lista de argumentos delimitados por paréntesis y separados por comas
Argumentos
El paso de argumentos es opcional y en algunos casos puede haber funciones que carezcan de ellos
Por ejemplo la función phpinfo no tiene argumentos
Esta función nos muestra información referente al módulo PHP que estamos usando y siempre devuelve el valor entero 1
Tipo de los argumentos
A partir de PHP 7 se puede declarar de forma opcional el tipo de los argumentos pasados a la función
Admite los tipos string, int, float, array, callable y clases
Si el usuario de la función los introduce mal o utiliza otro tipo de dato, PHP devolverá un mensaje de error indicándolo
Argumentos con valor por defecto
En ocasiones necesitamos que un argumento tenga un valor, para evitar un error, aunque el usuario de la función no lo introduzca
Hay que tener en cuenta, que los argumentos con valor por defecto pasan a ser opcionales y que todos los argumentos a la izquierda del primer valor por defecto, son obligatorios
Argumentos por valor o por referencia
Cuando pasamos un valor a una función, aunque lo modifiquemos, al salir de la función conservará su valor original
Esta es la situación por defecto y se denomina que es un argumento por valor
Ya que se utiliza una copia en memoria de la variable y cuando se sale de la función, esa copia de la variable se destruye
En el caso de que quisiéramos que los cambios realizados en el valor de la variable se conservarán después de salir de la función, deberemos usar el símbolo & delante del nombre de la variable
A esta situación se denomina que es un argumento por referencia
Ya que se utiliza una referencia a la variable en memoria, trabajando directamente sobre la variable y cuando se sale de la función, todos los cambios permanecen
Hasta PHP 5.0.5 era posible indicar que una función era por referencia usando el símbolo & delante del nombre de la función
Sin embargo, a partir de PHP 5.3.0 pasaría a indicar con un mensaje call-time pass-by-reference que su uso estaba obsoleto
A partir de PHP 5.4.0 fue totalmente eliminado y actualmente produce un error fatal
Es decir, sólo puede utilizarse el símbolo & al pasar argumentos, nunca en el nombre de la función
Sólo podemos pasar por referencia:
- Variables
- Referencias devueltas desde funciones
La sentencia return
La sentencia return es la que permite devolver el resultado de una función
A partir de PHP 7 se puede declarar de forma opcional el tipo devuelto por la función
Admite los tipos string, int, float, array, callable y clases
Para declarar el tipo se escribirá el símbolo : después de los paréntesis que siguen a los argumentos y antes de la llave de inicio {
Funciones predefinidas por el lenguaje
Funciones de visualización
Echo
La función echo sirve para enviar la salida de sus argumentos al navegador
Lo hemos usado continuamente en ejemplos previos
Tiene el formato:
Tiene las siguientes particularidades:
-
Podemos prescindir de los paréntesis en su uso, ya que son opcionales
-
Convierte toda la información a string antes de enviarla al navegador
-
Si utilizamos varios echo seguidos, nos encontraremos que el resultado lo concatena en la misma línea
Para solucionarlo deberemos utilizar la etiqueta HTML <br/> para que salte de línea
-
Si utilizamos varios echo seguidos, nos encontraremos que el resultado no añade un espacio al final y por tanto, el contenido podría mostrar textos incomprensibles, al carecer de ese espacio
Para solucionarlo deberemos añadir un espacio al final del primer echo o al principio del siguiente echo
printf
La función printf sirve para enviar la salida de sus argumentos al navegador con un formato
Tiene el formato:
Para formatear un texto deberemos introducir los siguientes caracteres de formato precedidos por el símbolo %:
Caracteres de formato para texto | |
Caracter | Descripción |
% |
Carácter de porcentaje literal No requiere un argumento |
b |
El argumento es tratado como un valor de tipo integer y presentado como un número binario |
c |
El argumento es tratado como un valor de tipo integer y presentado como el carácter con ese valor ASCII |
d |
El argumento es tratado como un valor de tipo integer y presentado como un número decimal (con signo) |
e |
El argumento es tratado con notación científica (por ejemplo 1.2e+2) El especificador de precisión indica el número de dígitos después del punto decimal a partir de PHP 5.2.1. En versiones anteriores, se tomaba como número de dígitos significativos (menos uno) |
E |
Como %e pero utiliza la letra mayúscula (por ejemplo 1.2E+2) |
f |
El argumento es tratado como un valor de tipo float y presentado como un número de punto flotante (considerando la configuración regional) |
F |
El argumento es tratado como un valor de tipo float y presentado como un número de punto flotante (sin considerar la configuración regional) Disponible desde PHP 4.3.10 y PHP 5.0.3. |
g |
Igual que %e y %f |
G |
Igual que %E y %f |
o |
El argumento es tratado como un valor de tipo integer y presentado como un número octal |
s |
El argumento es tratado y presentado como un string |
u |
El argumento es tratado como un valor de tipo integer y presentado como un número decimal sin signo |
x |
El argumento es tratado como un valor de tipo integer y presentado como un número hexadecimal (con las letras en minúsculas) |
X |
El argumento es tratado como un valor de tipo integer y presentado como un número hexadecimal (con las letras en mayúsculas) |
sprintf
La función sprintf sirve para asignar a sus argumentos, de forma formateada, la variable de retorno
Tiene el mismo formato que printf y admite los mismos formatos
print_r
La función print_r sirve para enviar la salida de sus argumentos al navegador, mostrando información entendible por las personas sobre los argumentos
Es útil para poder depurar nuestro código
Tiene el siguiente formato:
Podemos usarlo para ver el contenido completo de un array
Funciones para cadenas
Vamos a ver algunas de las funciones para cadenas de uso más cotidiano
Si necesitas más, la lista completa la puedes encontrar en el manual de PHP
Mayúsculas y minúsculas
La función strtoupper devuelve una copia de la cadena en mayúsculas
La función strtolower devuelve una copia de la cadena en minúsculas
Extraer cadena
La función substr sirve para extraer una subcadena de la cadena que le pasamos como argumento
Tiene el siguiente formato:
Dónde $start es la posición de inicio de la subcadena y $length la longitud que tendrá la subcadena
Puede ser útil cuando necesitamos extraer una palabra de un texto y conocemos previamente su posición y su longitud
Hay que tener en cuenta que la posición $start debe empezar en 0
Longitud de la cadena
La función strlen sirve para contar la longitud de la cadena
Tiene el siguiente formato:
Retomando la cadena del ejemplo anterior
Posición de un carácter en la cadena
La función strpos sirve para encontrar la posición de un carácter concreto en la cadena
Tiene el siguiente formato:
Dónde encontramos la aguja ($needle, es el carácter a buscar) en el pajar ($haystack, es la cadena en la que buscamos) y $offset, que es opcional, es el número inicial en el que se empieza a buscar
Hay que tener en cuenta que la posición inicial empieza en cero
A no ser que especifiquemos el valor de $offset
Encontrar un texto
La función strstr sirve para encontrar la primera aparición de una cadena
Tiene el siguiente formato:
Es muy similar a substr, pero nos ahorra el tener que usar strpos de forma intermedia
Funciones para matrices
Vamos a ver algunas de las funciones para matrices de uso más cotidiano
Si necesitas más, la lista completa la puedes encontrar en el manual de PHP
Contar el número de elementos
La función count sirve para contar el número total de elementos
Tiene el siguiente formato:
De forma opcional podemos utilizar el argumento $mode que por defecto utiliza el valor COUNT_NORMAL (cuenta los elementos secuencialmente) y para arrays multidimensionales COUNT_RECURSIVE (cuenta los elementos de forma recursiva, es decir, recorre todos los arrays multidimensionales y suma el total de elementos)
Buscar un valor en la matriz
Comprobar si un valor existe
La función in_array sirve para comprobar si un valor existe dentro de una matriz
Tiene el siguiente formato:
Dónde encontramos la aguja ($needle, es el carácter a buscar) en el pajar ($haystack, es la cadena en la que buscamos) y $strict, que es opcional, si es TRUE comprobará los tipos de $needle en $haystack
Si $needle es un string, la comparación se realiza considerando las mayúsculas ó minúsculas
Encontrar el primer valor
La función array_search sirve para encontrar el primer valor, si existe, dentro de una matriz
Tiene el siguiente formato:
Dónde encontramos la aguja ($needle, es el carácter a buscar) en el pajar ($haystack, es la cadena en la que buscamos) y $strict, que es opcional, si es TRUE comprobará los tipos de $needle en $haystack
Si $needle es un string, la comparación se realiza considerando las mayúsculas ó minúsculas
Hay que tener cuidado con los valores devueltos por esta función porque puede devolver el valor booleano FALSE, pero también puede devolver un valor no booleano que se evalúa como FALSE
En versiones anteriores a PHP 4.2.0 devolvía NULL en caso de fallo, en lugar de FALSE
A partir de PHP 5.3.0 devuelve NULL si se le pasan parámetros inválidos
Formatos de fecha
PHP no dispone de un tipo para fechas
Para trabajar con fechas utilizar strings formateados con marcas de tiempo al estilo de UNIX
Estas marcas de tiempo son un valor de entero medido en segundos que empiezan a contar a partir del 1 de Enero de 1970
Marcas de tiempo
Para obtener la marca de tiempo actual podemos usar la función time que tiene el siguiente formato:
El valor obtenido es fácil de manipular, ya que podemos sumarle múltiplos:
- de 3600 para añadirle horas
- de 86400 para añadirle días
- de 604800 para añadirle semanas
Cadena con formato
También podemos usar una cadena de formato para trabajar con fechas usando la función date que tiene el siguiente formato:
Donde $format es el cadena con el formato que queremos usar, $timestamp, que es opcional y por defecto se toma la función time, es una marca de tiempo UNIX
Para formatear una fecha deberemos introducir los siguientes caracteres de formato:
Caracteres de formato de fechas | |
Caracter | Descripción |
d |
Día del mes, 2 dígitos con ceros iniciales |
D |
Cadena para el día, tres letras |
j |
Día del mes sin ceros iniciales |
l (L minúscula) |
Cadena para el día de la semana |
N |
Representación numérica ISO-8601 del día de la semana Añadido en PHP 5.1.0. |
S |
Sufijo ordinal en inglés para el día del mes, 2 caracteres |
w |
Representación numérica del día de la semana |
z |
El día del año (comenzando por 0) |
W |
Número de la semana del año ISO-8601, las semanas comienzan en lunes |
F |
Una representación textual completa de un mes, como January o March |
m |
Representación numérica de una mes, con ceros iniciales |
M |
Una representación textual corta de un mes, tres letras |
n |
Representación numérica de un mes, sin ceros iniciales |
t |
Número de días del mes dado |
L |
Si es un año bisiesto |
o |
Año según el número de la semana ISO-8601 Esto tiene el mismo valor que Y, excepto que si el número de la semana pertenece al año anterior o siguiente, se usa ese año en su lugar Añadido en PHP 5.1.0. |
Y |
Una representación numérica completa de un año, 4 dígitos |
y |
Una representación de dos dígitos de un año |
a |
am o pm en minúsculas |
A |
am o pm en mayúsculas |
B |
Hora Internet |
g |
Formato de 12 horas de una hora sin ceros iniciales |
G |
Formato de 24 horas de una hora sin ceros iniciales |
h |
Formato de 12 horas de una hora con ceros iniciales |
H |
Formato de 24 horas de una hora con ceros iniciales |
i |
Minutos con ceros iniciales |
s |
Segundos con ceros iniciales |
u |
Microsegundos Añadido en PHP 5.2.2. date() siempre generará 000000 al tomar un parámetro de tipo integer, mientras que DateTime::format() admite microsegundos si el DateTime fue creado con microsegundos |
v |
Milisegundos Añadido en PHP 7.0.0. La misma observación que para u |
e |
Identificador de zona horaria Añadido en PHP 5.1.0. |
I (i mayúscula) |
La fecha está en horario de verano o no |
O |
Diferencia de la hora de Greenwich (GMT) en horas |
P |
Diferencia con la hora de Greenwich (GMT) con dos puntos entre horas y minutos Añadido en PHP 5.1.3 |
T |
Abreviatura de la zona horaria |
Z |
Índice de la zona horaria en segundos El índice para zonas horarias al oeste de UTC siempre es negativo, y para aquellas al este de UTC es siempre positivo |
c |
Fecha ISO 8601 Añadido en PHP 5 |
r |
Fecha con formato RFC 2822 |
U |
Segundos en formato UNIX (1 de Enero del 1970 00:00:00 GMT) |
Obtener una fecha desde una cadena
Usando un delimitador
A partir de una cadena podemos recoger una fecha usando la función explode que tiene el siguiente formato:
Donde $delimiter es el carácter usado para delimitar los valores, $string la cadena que contiene la fecha que queremos manipular y $limit un valor opcional cuyo valor por defecto es 1, que indica el máximo de valores devueltos
Si $limit es negativo se devolverán todos los valores eliminando el valor de $limit a partir del final
Y si es 0 se tratará como 1
Y después usaremos la función mktime para crear la marca de tiempo de tipo UNIX, que tiene el siguiente formato:
Donde $hour es la hora, $minute son los minutos, $second, los segundos, $month es el mes, $day es el día, $year es el año y $is_dst es el horario de verano o no (-1 si no lo es)
Todos los parámetros son opcionales, en caso de no introducir ninguno, se tomará el resultado de la función time
A partir de 5.1, cuando se hace la llamada sin argumentos, lanza un aviso de tipo E_STRICT: use la función time() en su lugar
Convirtiendo una cadena a formato de fecha
A partir de una cadena podemos recoger una fecha usando la función strtotime que tiene el siguiente formato:
Donde $time es la cadena de la que queremos obtener la fecha, $now, que es opcional y por defecto se toma la función time, es una marca de tiempo UNIX
A partir de PHP 5.0.0 los microsegundos comenzaron a estar permitidos, pero eran ignorados
En PHP 5 hasta 5.0.2, now y otros momentos relativos son computados erróneamente como la medianoche de hoy
Esto difiere entre versiones donde es computado como el momento actual
A partir de PHP 5.1.0 muestra el error E_STRICT y E_NOTICE cuando ocurren errores con zonas horarias
Y devuelve FALSE si falla, en vez de -1
En PHP 5 hasta 5.2.7, las peticiones de una incidencia de un día de la semana dado en un mes donde ese día de la semana era el primer día del mes, añadía incorrectamente una semana a la marca de tiempo devuelta
Esto fue corregido en 5.2.7 y se mantiene en versiones posteriores
Antes de PHP 5.3.0, 24:00 no era un formato válido y devolvía FALSE
Los formatos de tiempo relativos que se suministraban al parámetro $time como this week, previous week, last week, y next week se interpretaban como un período de 7 días en relación con la fecha y hora actual, en lugar de un período de la semana de Monday a Sunday