Cuando empezamos a programar en PHP, una de las primeras decisiones que tenemos que tomar es qué herramienta vamos a utilizar para escribir nuestro código. Existen IDEs muy completos, como PhpStorm, NetBeans o Eclipse PDT, pero para un curso desde cero una de las opciones más equilibradas es Visual Studio Code.
Visual Studio Code, normalmente conocido como VS Code, es un editor de código gratuito, ligero, multiplataforma y muy flexible. No es un IDE exclusivo para PHP, pero gracias a sus extensiones puede convertirse en un entorno muy potente para desarrollar aplicaciones web.
En este artículo veremos por qué VS Code es una buena opción para trabajar con PHP, qué ventajas tiene para el aprendizaje y qué extensiones conviene instalar.
📹 Instalación VSCODE
¿Qué es Visual Studio Code?
Visual Studio Code es un editor de código desarrollado por Microsoft. Está disponible para Windows, macOS y Linux, por lo que resulta muy cómodo en un entorno educativo donde cada alumno puede tener un sistema operativo diferente.
A diferencia de otros IDEs más pesados, VS Code parte de una base sencilla y se puede ampliar mediante extensiones. Esto significa que podemos instalar solo lo que necesitamos para cada momento del curso.
Por ejemplo, en un proyecto PHP podemos trabajar con archivos como estos:
Desde VS Code podemos abrir toda la carpeta del proyecto y trabajar cómodamente con todos estos archivos.
📹 Mí primer Hola Mundo
¿Por qué usar VS Code para PHP?
PHP es un lenguaje que se ejecuta normalmente en un servidor web. Es decir, nosotros escribimos el código en archivos .php, pero para ver el resultado necesitamos ejecutarlo mediante un servidor como Apache, Nginx, el servidor integrado de PHP o un entorno como XAMPP, MAMP, Laragon o Docker.
VS Code encaja muy bien en este flujo porque nos permite escribir, organizar y revisar el código de forma clara.
El flujo básico sería:
Escribir código en VS Code ↓ Guardar el archivo PHP ↓ Ejecutarlo mediante un servidor ↓ Ver el resultado en el navegador ↓ Corregir errores y volver a probar
Esta forma de trabajar ayuda mucho al alumno, porque ve claramente qué papel cumple cada herramienta.
Herramienta
Función
VS Code
Escribir y organizar el código
PHP
Interpretar el código del servidor
Apache / Nginx / servidor PHP
Servir la aplicación web
Navegador
Mostrar el resultado
MySQL / MariaDB
Almacenar los datos
phpMyAdmin / DBeaver / DataGrip
Gestionar la base de datos
Ventajas de VS Code en un curso de PHP
Es gratuito
Una ventaja muy importante es que VS Code es gratuito. Esto permite que todos los alumnos puedan instalarlo sin depender de licencias.
Para un entorno educativo esto es fundamental, porque evita problemas económicos y facilita que todos trabajen con la misma herramienta.
Funciona en Windows, macOS y Linux
VS Code está disponible para los principales sistemas operativos. Esto nos permite usarlo en diferentes escenarios:
Sistema
Entorno PHP habitual
Windows
XAMPP, Laragon, Docker
macOS
MAMP, XAMPP, Docker, PHP instalado con Homebrew
Linux
Apache, Nginx, PHP, Docker
El editor será el mismo, aunque el servidor PHP pueda cambiar según el sistema operativo.
Es ligero y sencillo
VS Code no es tan pesado como un IDE completo. Esto hace que sea más rápido de instalar, abrir y utilizar.
Para alumnos que empiezan, esto es una ventaja importante. Una interfaz demasiado cargada puede distraer más que ayudar.
Con VS Code podemos empezar con algo muy simple:
<?php echo "Hola mundo desde PHP"; ?>
Y poco a poco ir avanzando hacia proyectos más completos.
Se adapta al nivel del alumno
Otra ventaja es que podemos ir añadiendo extensiones según avanza el curso.
Al principio podemos instalar solo lo básico. Más adelante, cuando trabajemos con bases de datos, Git, depuración o Docker, podremos añadir nuevas extensiones.
Esto permite que el alumno no se vea saturado desde el primer día.
VS Code no ejecuta PHP por sí solo
Este punto es muy importante.
VS Code sirve para escribir código, pero no sustituye al servidor PHP.
Para ejecutar un archivo PHP necesitamos tener PHP instalado y, normalmente, trabajar con un servidor web.
No basta con abrirlo directamente en el navegador como si fuera un archivo HTML. Necesitamos ejecutarlo desde un servidor.
Una opción rápida es usar el servidor integrado de PHP. Desde la carpeta del proyecto podemos escribir:
php -S localhost:8000
Después abrimos el navegador y accedemos a:
http://localhost:8000
Para proyectos más completos podemos usar Apache, Nginx, XAMPP, MAMP, Laragon o Docker.
Extensiones recomendadas para PHP en VS Code
Una de las grandes ventajas de VS Code es su sistema de extensiones. A continuación veremos algunas de las más útiles para trabajar con PHP.
📹 Instalación de Extensiones o Plugins
PHP Intelephense
PHP Intelephense es una de las extensiones más importantes para programar en PHP con VS Code.
Añade funciones como:
Función
Utilidad
Autocompletado
Ayuda a escribir funciones, variables, clases y métodos
Detección de errores
Marca posibles errores antes de ejecutar
Ir a definición
Permite saltar a donde está definida una función o clase
Ayuda contextual
Muestra información sobre parámetros y métodos
Mejor soporte para proyectos grandes
Entiende mejor la estructura del código
Esta extensión debería instalarse desde el principio del curso.
Ejemplo:
<?php
function saludar($nombre) { return "Hola, " . $nombre; }
echo saludar("Laura");
?>
Con PHP Intelephense, VS Code nos ayudará a detectar funciones, parámetros y posibles errores de escritura.
PHP Debug
PHP Debug permite conectar VS Code con Xdebug, una herramienta de depuración para PHP.
Depurar significa ejecutar el programa paso a paso para ver qué está ocurriendo realmente. Esto es muy útil cuando un programa no falla por sintaxis, pero no hace lo que esperamos.
Por ejemplo:
<?php
$edad = 17;
if ($edad >= 18) { echo "Puede acceder"; } else { echo "No puede acceder"; }
?>
Con depuración podemos detener el programa antes del if y comprobar el valor real de la variable $edad.
PHP Debug permite:
Función
Utilidad
Puntos de interrupción
Parar el programa en una línea concreta
Ejecución paso a paso
Ver cómo avanza el programa
Inspección de variables
Comprobar valores durante la ejecución
Depuración de formularios
Ver datos enviados por GET o POST
Detección de errores lógicos
Encontrar fallos que no son de sintaxis
No es necesario instalarla el primer día, pero sí es muy recomendable cuando los alumnos ya trabajen con formularios, funciones, sesiones y bases de datos.
PHP DocBlocker
PHP DocBlocker ayuda a crear comentarios de documentación para funciones, clases y métodos.
Por ejemplo, si tenemos esta función:
function calcularTotal($precio, $cantidad) { return $precio * $cantidad; }
Podemos documentarla así:
/** * Calcula el precio total de una compra. * * @param float $precio * @param int $cantidad * @return float */ function calcularTotal($precio, $cantidad) { return $precio * $cantidad; }
Esta extensión resulta útil cuando empezamos a trabajar con funciones y programación orientada a objetos.
Documentar el código es una buena práctica que ayuda a que otros programadores puedan entender mejor nuestro proyecto.
Prettier
Prettier es una extensión para formatear código.
En proyectos PHP no solo escribimos PHP. También solemos trabajar con HTML, CSS y JavaScript. Prettier ayuda a mantener estos archivos ordenados y con un formato consistente.
Por ejemplo, puede ayudarnos con código HTML como este:
Este ejemplo es interesante porque muestra una de las características habituales de PHP: la mezcla de código PHP con HTML.
Desde VS Code escribimos el código, pero para verlo correctamente tendremos que ejecutarlo desde un servidor PHP.
Recomendación para clase
Para un curso de PHP desde cero, mi recomendación sería empezar con pocas extensiones:
Extensión
Prioridad
PHP Intelephense
Obligatoria
Material Icon Theme
Recomendada
Prettier
Recomendada
Auto Rename Tag
Recomendada cuando usemos HTML
GitLens
Cuando empecemos con Git
PHP Debug
Cuando empecemos con depuración
SQLTools
Cuando avancemos con bases de datos
Docker
Cuando trabajemos con contenedores
No es buena idea instalar demasiadas extensiones al principio. Puede parecer que estamos mejorando el entorno, pero en realidad podemos confundir al alumno.
Lo ideal es que el entorno crezca al mismo ritmo que el curso.
Conclusión
Visual Studio Code es una herramienta muy adecuada para aprender PHP porque combina sencillez, potencia y flexibilidad.
Nos permite empezar con scripts básicos y avanzar poco a poco hacia proyectos más completos con HTML, CSS, JavaScript, formularios, sesiones, bases de datos, Git, depuración y Docker.
Pero conviene recordar una idea importante:
VS Code no es el servidor. VS Code es la herramienta donde escribimos el código. PHP necesita un entorno de ejecución para funcionar.
Por eso, en un curso de PHP deberíamos enseñar siempre la relación entre el editor, el servidor, el lenguaje y el navegador.
El objetivo no es solamente aprender a usar VS Code. El objetivo es entender el proceso completo de desarrollo de una aplicación web con PHP:
Editor → Código PHP → Servidor → Navegador → Pruebas → Corrección → Nueva versión
Cuando empezamos a programar en PHP, lo primero que debemos entender no es todavía cómo crear una aplicación completa, ni cómo conectar con una base de datos, ni cómo hacer un formulario avanzado. Antes de todo eso necesitamos aprender a escribir PHP correctamente.
PHP es un lenguaje que normalmente se ejecuta en el servidor. Eso significa que el navegador no interpreta directamente el código PHP. El navegador pide una página al servidor, el servidor ejecuta el PHP y finalmente devuelve al navegador una respuesta, normalmente HTML. Por eso, aunque nosotros escribamos código PHP, el usuario final normalmente solo recibe el resultado.
En este primer tema vamos a trabajar la base de la sintaxis de PHP: cómo se abre y se cierra un bloque PHP, cómo se escriben instrucciones, cómo se declaran variables, qué tipos de datos básicos existen y cómo podemos mostrar información en pantalla usando herramientas como echo, print, var_dump(), print_r(), printf() o var_export().
La idea no es memorizarlo todo de golpe, sino empezar a leer y escribir código PHP con seguridad.
1. Cómo se escribe código PHP
Un archivo PHP normalmente tiene extensión .php. Dentro de ese archivo podemos escribir HTML normal y, cuando queramos que el servidor ejecute código PHP, debemos abrir un bloque PHP.
La forma estándar de abrir PHP es:
<?php // Código PHP aquí ?>
La etiqueta de apertura <?php indica al intérprete que a partir de ese punto empieza código PHP. La etiqueta de cierre ?> indica que termina el bloque PHP. La documentación oficial de PHP explica que estas etiquetas sirven para marcar los límites del código PHP que debe ejecutarse dentro del archivo.
En este ejemplo hay una mezcla de HTML y PHP. El HTML se entrega tal cual al navegador, mientras que la parte PHP se ejecuta en el servidor. El resultado final que verá el navegador será algo parecido a esto:
<h1>Bienvenido a mi página</h1> Este texto lo ha generado PHP
El navegador no ve el código PHP original. Solo ve el resultado.
2. La etiqueta <?php
La etiqueta correcta y recomendable para abrir PHP es:
<?php
Es importante no confundirla con otras formas antiguas o menos recomendables como:
<?
Esa forma corta puede funcionar en algunos servidores, pero depende de la configuración de PHP. Por eso, para aprender bien y evitar problemas, usaremos siempre <?php.
También existe una etiqueta corta especial para imprimir valores:
<?= $variable ?>
Esta etiqueta equivale a escribir:
<?php echo $variable; ?>
Es decir, estas dos líneas hacen lo mismo:
<p><?= $nombre ?></p>
<p><?php echo $nombre; ?></p>
La etiqueta <?= es una forma abreviada de <?php echo, y PHP la reconoce como una etiqueta de salida corta.
Para un alumno que está empezando, mi recomendación es clara: al principio utiliza siempre <?php echo ... ?>. Cuando ya estés cómodo leyendo código PHP, puedes empezar a usar <?= ... ?> en plantillas HTML porque es más cómodo y limpio.
3. ¿Hay que cerrar siempre PHP con ?>?
En archivos donde mezclamos HTML y PHP, sí es normal cerrar el bloque PHP:
<h1> <?php echo "Hola mundo"; ?> </h1>
Pero cuando un archivo contiene solamente PHP, es habitual no cerrar la etiqueta final.
Por ejemplo:
<?php
$nombre = "Laura"; $edad = 25;
echo $nombre;
En este caso no hemos puesto ?> al final. Esto es habitual en archivos PHP puros, especialmente en proyectos profesionales. La razón es sencilla: evita errores provocados por espacios o saltos de línea accidentales después del cierre de PHP.
Para esta primera parte del curso podemos usar ambas formas, pero conviene que el alumno vaya entendiendo esta regla práctica:
Cuando el archivo mezcla HTML y PHP, podemos cerrar PHP. Cuando el archivo solo contiene PHP, normalmente dejamos el archivo sin cierre final.
4. Las instrucciones en PHP
Una instrucción es una orden que le damos al lenguaje. Por ejemplo:
echo "Hola mundo";
Esta instrucción le dice a PHP que muestre el texto "Hola mundo".
En PHP, la mayoría de instrucciones terminan con punto y coma:
$nombre = "Ana"; $edad = 20; echo $nombre;
El punto y coma ; es muy importante. Si se nos olvida, PHP normalmente mostrará un error de sintaxis.
Ejemplo incorrecto:
<?php $nombre = "Ana" echo $nombre;
El problema está en que falta el punto y coma después de "Ana".
La versión correcta sería:
<?php $nombre = "Ana"; echo $nombre;
Al principio puede parecer un detalle pequeño, pero muchos errores de principiantes en PHP vienen precisamente de olvidar un ;, una comilla o una llave.
5. Comentarios en PHP
Los comentarios son textos que escribimos dentro del código, pero que PHP no ejecuta. Sirven para explicar algo, dejar notas o desactivar temporalmente una línea.
PHP permite comentarios de una línea:
<?php
// Esto es un comentario de una línea
$nombre = "Carlos"; // También puedo comentar al final de una línea
echo $nombre;
También permite comentarios de varias líneas:
<?php
/* Este es un comentario de varias líneas. PHP no ejecutará nada de lo que haya aquí dentro. */
echo "Hola";
Los comentarios deben usarse con cabeza. Un buen comentario no explica lo evidente, sino la intención del código.
Este comentario aporta poco:
<?php
// Creamos una variable nombre $nombre = "Ana";
Este comentario sí puede ser útil:
<?php
// Guardamos el nombre que se mostrará en la cabecera de la página $nombre = "Ana";
6. Variables en PHP
Una variable es un espacio donde guardamos un valor. Ese valor puede ser un texto, un número, un verdadero/falso, una lista de datos, etc.
En PHP, todas las variables empiezan con el símbolo $.
$nombre guarda un texto. $edad guarda un número entero. $precio guarda un número decimal. $activo guarda un valor booleano, es decir, verdadero o falso.
La documentación oficial de PHP recoge las variables como una parte fundamental de la referencia del lenguaje.
En PHP no hace falta declarar el tipo de dato al crear una variable. No escribimos esto:
string $nombre = "Ana"; int $edad = 22;
Aunque PHP sí permite usar declaraciones de tipo en funciones y clases, en la creación básica de variables normalmente escribimos directamente:
$nombre = "Ana"; $edad = 22;
PHP detecta el tipo de dato según el valor que le asignamos.
7. Reglas básicas para nombres de variables
Una variable en PHP debe empezar siempre con $.
Después del $, el nombre de la variable debe empezar por una letra o por guion bajo _. No debe empezar por un número.
Para guardar un valor en una variable usamos el operador de asignación =.
<?php
$nombre = "Lucía";
Esta línea no significa “nombre es igual a Lucía” en sentido matemático. Significa: guarda el valor "Lucía" dentro de la variable $nombre.
Podemos cambiar el valor de una variable más adelante:
<?php
$nombre = "Lucía"; echo $nombre;
$nombre = "Mario"; echo $nombre;
Primero $nombre vale "Lucía". Después cambia y pasa a valer "Mario".
También podemos crear una variable a partir de otras variables:
<?php
$precio = 100; $iva = 21;
$precioConIva = $precio + ($precio * $iva / 100);
echo $precioConIva;
En este caso, PHP calcula el precio con IVA y guarda el resultado en $precioConIva.
9. Tipos de datos básicos en PHP
Aunque PHP permite trabajar de forma flexible, es fundamental entender los tipos de datos. Un tipo de dato indica qué clase de valor tenemos entre manos.
No es lo mismo esto:
$edad = 25;
que esto:
$edad = "25";
En el primer caso tenemos un número entero. En el segundo caso tenemos un texto que contiene los caracteres 2 y 5.
PHP tiene varios tipos de datos. En este tema vamos a trabajar los más importantes para empezar: cadenas de texto, enteros, decimales, booleanos, nulos y arrays. PHP incluye en su referencia oficial una sección completa dedicada a los tipos del lenguaje, como booleanos, enteros, números de punto flotante, strings, arrays, objetos, null y otros.
10. Texto o string
Un string es una cadena de texto. Puede contener letras, números, espacios y símbolos.
<?php
$nombre = "Ana"; $ciudad = "Madrid"; $mensaje = "Bienvenido al curso de PHP";
Podemos escribir strings usando comillas dobles:
$nombre = "Ana";
O comillas simples:
$nombre = 'Ana';
Las dos formas sirven, pero tienen una diferencia importante. Con comillas dobles, PHP puede interpretar variables dentro del texto:
<?php
$nombre = "Ana";
echo "Hola $nombre";
Resultado:
Hola Ana
Con comillas simples, PHP no sustituye la variable:
<?php
$nombre = "Ana";
echo 'Hola $nombre';
Resultado:
Hola $nombre
Por eso, si queremos insertar variables directamente dentro de un texto, podemos usar comillas dobles.
También podemos concatenar textos usando el punto .:
<?php
$nombre = "Ana";
echo "Hola " . $nombre;
Resultado:
Hola Ana
La concatenación es muy importante en PHP. El operador . une textos.
Los booleanos serán fundamentales cuando trabajemos con condiciones.
Por ejemplo:
<?php
$usuarioActivo = true;
if ($usuarioActivo) { echo "El usuario puede acceder."; } else { echo "El usuario no puede acceder."; }
Aunque todavía no hayamos estudiado en profundidad los if, este ejemplo nos permite ver para qué sirve un booleano. La variable $usuarioActivo representa una decisión: sí o no, verdadero o falso.
14. Valor nulo o null
null representa la ausencia de valor.
<?php
$telefono = null;
No significa que el teléfono sea un texto vacío. No significa que sea cero. Significa que no hay valor.
Esto es diferente:
$telefono = "";
Aquí sí hay un valor: una cadena vacía.
Y esto también es diferente:
$telefono = 0;
Aquí hay un valor numérico: cero.
null se utiliza mucho cuando un dato todavía no existe, cuando no se ha rellenado o cuando queremos indicar expresamente que una variable no tiene contenido.
Ejemplo:
<?php
$segundoApellido = null;
var_dump($segundoApellido);
Resultado aproximado:
NULL
15. Arrays
Un array permite guardar varios valores dentro de una misma variable. Según la documentación oficial, en PHP un array es realmente un mapa ordenado, es decir, una estructura que asocia claves con valores. Esto permite usarlo como lista, diccionario, colección y otras estructuras.
Un array sencillo sería:
<?php
$frutas = ["manzana", "pera", "plátano"];
Podemos acceder a cada elemento usando su posición. En PHP, como en muchos lenguajes, las posiciones empiezan en cero.
Los arrays son muy importantes en PHP. Los usaremos más adelante para manejar datos de formularios, resultados de bases de datos, configuraciones, sesiones y muchas otras partes de una aplicación web.
16. Cambios de tipo en PHP
PHP es un lenguaje flexible. Una misma variable puede contener primero un texto y después un número.
<?php
$dato = "Hola"; $dato = 25; $dato = true;
Esto funciona, pero no siempre es buena idea abusar de ello.
Cuando estamos aprendiendo, conviene que una variable tenga un sentido claro. Si una variable se llama $edad, debería guardar una edad. Si se llama $nombre, debería guardar un nombre. Si se llama $precio, debería guardar un precio.
La flexibilidad de PHP es cómoda, pero también puede esconder errores. Por eso es importante escribir nombres de variables claros y comprobar los valores mientras programamos.
17. Mostrar información con echo
echo es una de las formas más habituales de mostrar información en PHP.
<?php
echo "Hola mundo";
También podemos mostrar el contenido de una variable:
Este segundo estilo suele ser más cómodo cuando estamos creando vistas o plantillas HTML.
18. Mostrar información con print
print es parecido a echo.
<?php
print "Hola mundo";
También puede mostrar variables:
<?php
$nombre = "Carlos";
print $nombre;
En el uso diario, echo es más habitual. Para un alumno que empieza, podemos decir que ambos sirven para mostrar información, pero usaremos principalmente echo.
var_dump() es una herramienta fundamental para aprender y depurar código PHP.
Mientras echo muestra un valor de forma sencilla, var_dump() muestra información más detallada: el tipo de dato y el valor. La documentación oficial indica que var_dump() muestra información estructurada de una o más expresiones, incluyendo su tipo y su valor.
Esto es muy útil para entender qué está pasando realmente.
Por ejemplo, observa este caso:
<?php
$edad = "22";
var_dump($edad);
Resultado:
string(2) "22"
Aunque visualmente parezca un número, PHP nos está diciendo que es un texto de dos caracteres.
Ahora mira este otro:
<?php
$edad = 22;
var_dump($edad);
Resultado:
int(22)
Ahora sí es un número entero.
Esta diferencia será muy importante cuando trabajemos con formularios, porque muchos datos que llegan desde un formulario llegan inicialmente como texto.
20. Usar <pre> con var_dump()
Cuando usamos var_dump() en el navegador, el resultado puede verse poco ordenado, especialmente con arrays.
Este recurso lo usaremos muchísimo durante el aprendizaje.
21. print_r(): ver arrays de forma más simple
print_r() también sirve para inspeccionar variables, especialmente arrays. No muestra tanta información como var_dump(), pero a veces es más fácil de leer.
La diferencia principal es que print_r() muestra la estructura de forma más limpia, pero no indica con tanto detalle los tipos de datos.
Comparemos:
<?php
$edad = "22";
echo "<pre>"; print_r($edad); echo "</pre>";
echo "<pre>"; var_dump($edad); echo "</pre>";
print_r() mostraría algo parecido a:
22
var_dump() mostraría:
string(2) "22"
Para aprender, var_dump() suele ser mejor porque nos dice el tipo. Para revisar arrays grandes de forma rápida, print_r() puede resultar más cómodo.
22. printf(): salida con formato
printf() permite mostrar texto usando marcadores de posición. Es muy útil cuando queremos construir una frase con valores variables de forma más controlada.
Ejemplo básico:
<?php
$nombre = "Ana"; $edad = 22;
printf("Me llamo %s y tengo %d años.", $nombre, $edad);
Resultado:
Me llamo Ana y tengo 22 años.
Aquí aparecen dos marcadores:
%s se usa para cadenas de texto. %d se usa para números enteros.
Para imprimir el símbolo % usando printf(), escribimos %%.
23. sprintf(): guardar el texto formateado en una variable
sprintf() se parece mucho a printf(), pero no muestra directamente el resultado. En lugar de eso, devuelve el texto formateado para que podamos guardarlo en una variable.
24. var_export(): mostrar una representación válida en PHP
var_export() es otra herramienta de inspección. Se parece a var_dump(), pero tiene una diferencia interesante: genera una representación que se parece mucho a código PHP válido. La documentación oficial explica que var_export() obtiene información estructurada de una variable y que su representación es código PHP válido.
No es una función que necesitemos usar todo el tiempo al empezar, pero conviene conocerla. Puede ser útil cuando queremos ver una estructura de datos en un formato que luego podríamos copiar y reutilizar como código PHP.
25. Diferencia práctica entre echo, var_dump(), print_r() y printf()
La mejor forma de entender estas herramientas es verlas sobre el mismo dato.
echo "<h2>Con printf()</h2>"; printf( "El producto %s cuesta %.2f euros y tiene %d unidades en stock.", $producto["nombre"], $producto["precio"], $producto["stock"] );
Cada herramienta tiene un propósito distinto.
echo sirve para mostrar contenido sencillo.
print_r() sirve para ver estructuras como arrays de forma clara.
var_dump() sirve para ver estructura, valores y tipos de datos.
printf() sirve para construir una salida con formato.
var_export() sirve para ver una representación reutilizable como código PHP.
No hay que elegir una para todo. Lo importante es saber cuándo interesa cada una.
26. Primer ejemplo completo: datos de un alumno
Vamos a construir un ejemplo sencillo que combine variables, tipos de datos y salida por pantalla.
Este tipo de ejemplo es perfecto para clase, porque permite ver dos cosas a la vez: lo que se muestra al usuario y lo que PHP está manejando internamente.
27. Segundo ejemplo completo: producto de una tienda
Ahora vamos a usar un ejemplo más cercano a una aplicación web real: un producto de una tienda.
Aunque todavía no hayamos estudiado condiciones en profundidad, el ejemplo se entiende bastante bien. Tenemos un producto, un precio, un descuento y un cálculo final.
Este ejemplo también muestra por qué los tipos de datos importan:
$nombreProducto es texto. $precio es decimal. $unidadesDisponibles es entero. $tieneDescuento es booleano. $precioFinal se calcula a partir de otros valores.
28. Errores frecuentes al empezar con PHP
Uno de los errores más comunes es olvidar el punto y coma:
<?php
$nombre = "Ana" echo $nombre;
La forma correcta es:
<?php
$nombre = "Ana"; echo $nombre;
Otro error muy común es olvidar el símbolo $ delante de una variable:
<?php
nombre = "Ana";
La forma correcta es:
<?php
$nombre = "Ana";
También es frecuente mezclar mal las comillas:
<?php
echo "Hola mundo';
La forma correcta sería:
<?php
echo "Hola mundo";
O también:
<?php
echo 'Hola mundo';
Otro error habitual aparece al concatenar:
<?php
$nombre = "Ana";
echo "Hola " $nombre;
La forma correcta es usar el punto:
<?php
$nombre = "Ana";
echo "Hola " . $nombre;
También podemos usar comillas dobles con la variable dentro:
<?php
$nombre = "Ana";
echo "Hola $nombre";
Pero al principio recomiendo practicar bastante la concatenación con . porque ayuda a entender mejor cómo se construyen las cadenas.
29. Buenas prácticas desde el primer día
Aunque estemos empezando, conviene adquirir buenas costumbres desde el principio.
Una buena práctica es usar nombres de variables descriptivos:
También es buena idea usar var_dump() durante el aprendizaje. No debemos verlo como algo “de novatos”, sino como una herramienta de trabajo. Programar no consiste en adivinar qué está pasando. Programar consiste en comprobarlo.
30. Ejercicio guiado para el alumno
Crea un archivo llamado:
tema1_sintaxis.php
Dentro del archivo, crea una pequeña ficha personal usando variables.
Debe tener los siguientes datos:
Nombre. Edad. Ciudad. Curso. Nota media. Si está matriculado o no. Un dato opcional con valor null, por ejemplo, segundo teléfono.
Después, muestra la información en HTML usando echo y printf().
Finalmente, muestra una zona de depuración usando var_dump().
El objetivo no es solo que funcione. El objetivo es que el código se entienda.
32. Resumen final
En este tema hemos visto la base de la sintaxis de PHP. Ya sabemos que el código PHP se escribe dentro de bloques que empiezan normalmente con <?php. También hemos visto que las instrucciones suelen terminar con punto y coma y que los comentarios nos permiten documentar el código sin que PHP los ejecute.
Hemos aprendido que las variables en PHP empiezan con $ y que pueden guardar diferentes tipos de datos: textos, enteros, decimales, booleanos, valores nulos y arrays. También hemos visto que PHP es flexible con los tipos, pero que precisamente por eso debemos ser ordenados y claros al escribir nuestras variables.
Por último, hemos trabajado varias herramientas de salida. echo nos permite mostrar contenido sencillo. print es parecido, aunque lo usaremos menos. var_dump() nos muestra el tipo y el valor de una variable, lo que lo convierte en una herramienta excelente para aprender y depurar. print_r() resulta cómodo para ver arrays. printf() nos permite mostrar textos con formato, especialmente útil para números y precios. Y var_export() nos ofrece una representación más cercana a código PHP reutilizable.
A partir de aquí ya podemos empezar a escribir pequeños scripts PHP con sentido. Todavía son programas sencillos, pero esta base es imprescindible. Si el alumno domina bien variables, tipos y salida por pantalla, tendrá mucho más fácil entender condiciones, bucles, funciones, formularios y bases de datos en los siguientes temas.
Hasta ahora hemos visto cómo escribir nuestros primeros scripts en PHP, cómo crear variables, cómo mostrar información en pantalla y cómo trabajar con distintos tipos de datos. Todo eso nos permite guardar y enseñar información, pero todavía nos falta algo fundamental: hacer que el programa tome decisiones.
Un programa real no ejecuta siempre las mismas instrucciones de forma lineal. A veces debe comprobar una condición y actuar de una manera u otra. Por ejemplo:
Un usuario puede ser mayor o menor de edad.
Una contraseña puede ser correcta o incorrecta.
Un producto puede tener stock o estar agotado.
Una nota puede estar aprobada o suspensa.
Un usuario puede ser administrador o cliente normal.
Para resolver este tipo de situaciones utilizamos condicionales.
En PHP, igual que en muchos otros lenguajes de programación, las estructuras condicionales nos permiten ejecutar un bloque de código solamente si se cumple una condición.
1. ¿Qué es una condición?
Una condición es una expresión que PHP puede evaluar como verdadera o falsa.
Por ejemplo:
$edad = 20;
$edad >= 18
La expresión anterior comprueba si la variable $edad es mayor o igual que 18.
Como $edad vale 20, la condición se cumple. Es decir, PHP la considera verdadera.
Si cambiamos el valor:
$edad = 15;
$edad >= 18
Ahora la condición no se cumple, porque 15 no es mayor o igual que 18.
Cuando trabajamos con condicionales, PHP evalúa expresiones que normalmente devuelven un valor booleano:
true false
Aunque en PHP también hay valores que pueden comportarse como verdaderos o falsos, como veremos más adelante.
2. El condicional if
La estructura condicional más básica es if.
Su traducción sería:
Si se cumple esta condición, ejecuta este bloque de código.
La estructura general es:
if (condicion) { // Código que se ejecuta si la condición es verdadera }
Ejemplo básico:
<?php
$edad = 20;
if ($edad >= 18) { echo "Eres mayor de edad."; }
?>
En este caso, como $edad vale 20, la condición $edad >= 18 se cumple y se mostrará el mensaje:
Eres mayor de edad.
Si cambiamos la edad:
<?php
$edad = 15;
if ($edad >= 18) { echo "Eres mayor de edad."; }
?>
No se mostrará nada, porque la condición no se cumple.
Esto es importante: si la condición de un if no se cumple, PHP ignora el bloque de código que está dentro de las llaves.
3. Ejemplo práctico: comprobar una nota
Vamos a imaginar que estamos creando una pequeña aplicación para mostrar si un alumno ha aprobado.
<?php
$nota = 7;
if ($nota >= 5) { echo "Has aprobado."; }
?>
Como la nota es 7, se muestra:
Has aprobado.
Pero si la nota fuese un 3, no aparecería ningún mensaje. Eso no es muy útil para el usuario, porque si ha suspendido también deberíamos informarle.
Para eso usamos else.
4. El condicional if...else
La estructura if...else permite ejecutar un bloque de código cuando la condición se cumple y otro bloque diferente cuando no se cumple.
Su traducción sería:
Si se cumple esta condición, haz esto. Si no se cumple, haz esto otro.
Estructura general:
if (condicion) { // Código si la condición es verdadera } else { // Código si la condición es falsa }
PHP considera que 5 y "5" son iguales en valor, aunque uno sea un número entero y el otro sea una cadena de texto.
Ahora usamos ===:
<?php
$numero = 5; $texto = "5";
if ($numero === $texto) { echo "Son iguales usando ===."; } else { echo "No son exactamente iguales."; }
?>
Resultado:
No son exactamente iguales.
¿Por qué? Porque $numero es un entero y $texto es una cadena.
En programación real, especialmente cuando trabajemos con formularios, bases de datos y sesiones, conviene acostumbrarse a usar === cuando queramos comprobar igualdad estricta.
8. Ejemplo práctico: comprobar usuario y contraseña
Para que el acceso sea permitido, ambas deben cumplirse.
Para unir condiciones usamos operadores lógicos.
9. Operadores lógicos
Los operadores lógicos permiten combinar varias condiciones.
Los principales son:
Operador
Nombre
Significado
&&
AND
Se cumplen todas las condiciones
`
`
!
NOT
Niega una condición
Aunque PHP también permite escribir and y or, en este nivel es recomendable usar && y ||, porque son más habituales y evitan algunos problemas de prioridad.
10. Uso de &&: todas las condiciones deben cumplirse
El operador && significa “y”.
Se utiliza cuando necesitamos que se cumplan varias condiciones a la vez.
Ejemplo:
<?php
$edad = 22; $tieneEntrada = true;
if ($edad >= 18 && $tieneEntrada === true) { echo "Puedes entrar al evento."; } else { echo "No puedes entrar al evento."; }
?>
Para poder entrar al evento deben cumplirse dos cosas:
La persona debe tener al menos 18 años. La persona debe tener entrada.
Si una de las dos falla, el resultado será negativo.
Podemos escribirlo también de forma un poco más natural:
<?php
$edad = 22; $tieneEntrada = true;
if ($edad >= 18 && $tieneEntrada) { echo "Puedes entrar al evento."; } else { echo "No puedes entrar al evento."; }
?>
Cuando una variable ya contiene true o false, no siempre es necesario compararla con true.
11. Uso de ||: basta con que se cumpla una condición
El operador || significa “o”.
Se utiliza cuando basta con que se cumpla una de varias condiciones.
Ejemplo:
<?php
$rol = "editor";
if ($rol === "admin" || $rol === "editor") { echo "Puedes acceder al panel de gestión."; } else { echo "No tienes permisos para acceder."; }
?>
En este caso, el usuario puede acceder si su rol es "admin" o si su rol es "editor".
Como $rol vale "editor", la condición se cumple.
Este tipo de comprobación se usa mucho en aplicaciones web con distintos tipos de usuario.
12. Uso de !: negar una condición
El operador ! sirve para negar una condición.
Es decir, convierte true en false y false en true.
Ejemplo:
<?php
$sesionIniciada = false;
if (!$sesionIniciada) { echo "Debes iniciar sesión para continuar."; }
?>
La variable $sesionIniciada vale false.
Al escribir:
!$sesionIniciada
Estamos diciendo:
Si NO hay sesión iniciada…
Por eso se muestra el mensaje.
Otro ejemplo:
<?php
$productoDisponible = false;
if (!$productoDisponible) { echo "El producto no está disponible."; } else { echo "Puedes comprar el producto."; }
?>
13. elseif: comprobar varias posibilidades
A veces no tenemos solo dos caminos posibles.
Por ejemplo, una nota no es simplemente aprobado o suspenso. También podemos querer distinguir entre suspenso, aprobado, notable y sobresaliente.
Para eso usamos elseif.
La estructura general es:
if (condicion1) { // Código si se cumple la primera condición } elseif (condicion2) { // Código si no se cumple la primera, pero sí la segunda } elseif (condicion3) { // Código si se cumple la tercera } else { // Código si no se cumple ninguna de las anteriores }
Primero comprueba si $nota < 5. Como 8 < 5 es falso, pasa al siguiente. Después comprueba si $nota < 7. Como 8 < 7 es falso, pasa al siguiente. Después comprueba si $nota < 9. Como 8 < 9 es verdadero, ejecuta ese bloque y ya no sigue comprobando más.
if ($edad >= 18) { if ($tieneEntrada) { if (!$estaVetado) { echo "Puedes entrar."; } else { echo "No puedes entrar porque estás vetado."; } } else { echo "No puedes entrar porque no tienes entrada."; } } else { echo "No puedes entrar porque eres menor de edad."; }
?>
Funciona, pero empieza a ser incómodo.
Podemos escribirlo de una forma más clara usando varias condiciones:
if ($edad < 18) { echo "No puedes entrar porque eres menor de edad."; } elseif (!$tieneEntrada) { echo "No puedes entrar porque no tienes entrada."; } elseif ($estaVetado) { echo "No puedes entrar porque estás vetado."; } else { echo "Puedes entrar."; }
?>
Este segundo código suele ser más fácil de leer porque va descartando casos.
Primero mira si la edad no es válida. Después mira si no tiene entrada. Después mira si está vetado. Y si no ocurre nada de eso, permite entrar.
Este estilo será muy útil cuando empecemos a validar formularios.
18. Condicionales con cadenas de texto
Los condicionales no solo sirven para números. También podemos comparar cadenas de texto.
Ejemplo:
<?php
$dia = "lunes";
if ($dia === "lunes") { echo "Hoy empieza la semana."; } else { echo "Hoy no es lunes."; }
?>
Otro ejemplo:
<?php
$estadoPedido = "pendiente";
if ($estadoPedido === "pendiente") { echo "Tu pedido está pendiente de preparación."; } elseif ($estadoPedido === "enviado") { echo "Tu pedido ya ha sido enviado."; } elseif ($estadoPedido === "entregado") { echo "Tu pedido ha sido entregado."; } else { echo "Estado del pedido desconocido."; }
?>
Este ejemplo se parece más a una situación real. Muchas aplicaciones trabajan con estados: usuarios activos o inactivos, pedidos pendientes, reservas aceptadas, productos agotados, pagos confirmados, etc.
19. Ejemplo práctico: estado de una reserva
Imaginemos que estamos desarrollando una aplicación de reservas.
Una reserva puede estar en distintos estados:
pendiente, aceptada, cancelada o finalizada.
<?php
$estadoReserva = "pendiente";
if ($estadoReserva === "pendiente") { echo "La reserva está pendiente de confirmación."; } elseif ($estadoReserva === "aceptada") { echo "La reserva ha sido aceptada."; } elseif ($estadoReserva === "cancelada") { echo "La reserva ha sido cancelada."; } elseif ($estadoReserva === "finalizada") { echo "La reserva ya ha finalizado."; } else { echo "El estado de la reserva no es válido."; }
?>
Este tipo de estructura se usará mucho cuando trabajemos con bases de datos. Por ejemplo, podemos guardar en una tabla el estado de una reserva y después mostrar un mensaje diferente según ese estado.
20. La estructura switch
Cuando tenemos que comparar una misma variable con muchos valores posibles, podemos usar switch.
Por ejemplo, este código con if funciona perfectamente:
<?php
$dia = "martes";
if ($dia === "lunes") { echo "Inicio de semana."; } elseif ($dia === "martes") { echo "Segundo día de la semana."; } elseif ($dia === "miércoles") { echo "Mitad de semana."; } elseif ($dia === "jueves") { echo "Casi viernes."; } elseif ($dia === "viernes") { echo "Último día laboral."; } else { echo "Fin de semana o día no reconocido."; }
?>
Pero también podemos escribirlo con switch:
<?php
$dia = "martes";
switch ($dia) { case "lunes": echo "Inicio de semana."; break;
case "martes": echo "Segundo día de la semana."; break;
case "miércoles": echo "Mitad de semana."; break;
case "jueves": echo "Casi viernes."; break;
case "viernes": echo "Último día laboral."; break;
default: echo "Fin de semana o día no reconocido."; break; }
?>
El switch compara el valor de $dia con cada uno de los case.
Cuando encuentra una coincidencia, ejecuta el código correspondiente.
El default se ejecuta si no coincide con ningún case.
21. La importancia de break en switch
En un switch, normalmente escribimos break al final de cada case.
El break sirve para salir del switch.
Si olvidamos el break, PHP puede seguir ejecutando los siguientes casos aunque no correspondan.
Ejemplo problemático:
<?php
$rol = "editor";
switch ($rol) { case "admin": echo "Acceso total.";
case "editor": echo "Acceso a edición.";
case "cliente": echo "Acceso a compras.";
default: echo "Rol desconocido."; }
?>
Si $rol vale "editor", PHP entra en el caso "editor", pero como no hay break, seguirá ejecutando también los bloques siguientes.
Por eso deberíamos escribirlo así:
<?php
$rol = "editor";
switch ($rol) { case "admin": echo "Acceso total."; break;
case "editor": echo "Acceso a edición."; break;
case "cliente": echo "Acceso a compras."; break;
default: echo "Rol desconocido."; break; }
?>
22. Ejemplo práctico con switch: menú de opciones
Imaginemos que tenemos una variable que representa la opción seleccionada por un usuario en un menú.
<?php
$opcion = 2;
switch ($opcion) { case 1: echo "Has seleccionado ver productos."; break;
case 2: echo "Has seleccionado ver el carrito."; break;
case 3: echo "Has seleccionado finalizar compra."; break;
case 4: echo "Has seleccionado salir."; break;
default: echo "Opción no válida."; break; }
?>
Este tipo de estructura es útil cuando estamos gestionando opciones cerradas y conocidas.
23. match: una alternativa moderna a switch
En versiones modernas de PHP existe también la expresión match.
Se parece a switch, pero tiene algunas diferencias importantes:
match devuelve un valor.
No necesita break.
Compara de forma estricta.
Suele ser más compacto.
Ejemplo:
<?php
$estadoPedido = "enviado";
$mensaje = match ($estadoPedido) { "pendiente" => "Tu pedido está pendiente.", "enviado" => "Tu pedido ha sido enviado.", "entregado" => "Tu pedido ha sido entregado.", "cancelado" => "Tu pedido ha sido cancelado.", default => "Estado desconocido.", };
echo $mensaje;
?>
Resultado:
Tu pedido ha sido enviado.
match es muy útil cuando queremos asignar un valor dependiendo de otro.
if ($nombre === "") { echo "El nombre es obligatorio."; } elseif ($edad === "") { echo "La edad es obligatoria."; } elseif ($email === "") { echo "El email es obligatorio."; } elseif ($edad < 18) { echo "Debes ser mayor de edad para registrarte."; } else { echo "Registro correcto."; }
?>
Este ejemplo ya se parece mucho más a una validación real.
Primero comprobamos que los campos obligatorios no estén vacíos. Después comprobamos una regla concreta: que la edad sea mayor o igual que 18. Finalmente, si todo está bien, mostramos el mensaje de registro correcto.
28. Mejorando la validación de edad
Hay un detalle importante. Los datos que llegan desde un formulario suelen llegar como texto, aunque el input sea de tipo number.
Por eso conviene validar bien.
<?php
$edad = $_POST["edad"] ?? "";
if ($edad === "") { echo "La edad es obligatoria."; } elseif (!is_numeric($edad)) { echo "La edad debe ser un número."; } elseif ($edad < 0 || $edad > 120) { echo "La edad no parece válida."; } elseif ($edad < 18) { echo "Debes ser mayor de edad."; } else { echo "Edad correcta."; }
?>
Aquí aparece una función nueva:
is_numeric($edad)
Esta función comprueba si un valor es numérico.
El operador ! delante significa “no”.
Por tanto:
!is_numeric($edad)
significa:
Si la edad no es numérica…
Este tipo de validación es esencial. Nunca debemos confiar ciegamente en los datos que llegan desde un formulario.
29. Condicionales y arrays
Aunque los arrays se estudiarán con más detalle más adelante, podemos ver ya un ejemplo sencillo.
Imaginemos que tenemos un array con productos:
<?php
$productos = ["teclado", "ratón", "monitor"];
$productoBuscado = "ratón";
if (in_array($productoBuscado, $productos)) { echo "El producto está disponible."; } else { echo "El producto no está disponible."; }
?>
La función in_array() comprueba si un valor existe dentro de un array.
En este caso, "ratón" sí está dentro del array, por lo que se muestra:
La función date("H") devuelve la hora actual en formato de 24 horas.
Si la hora es menor que 12, mostramos "Buenos días". Si no, pero es menor que 20, mostramos "Buenas tardes". En cualquier otro caso, mostramos "Buenas noches".
Este tipo de condicional puede usarse en una web para personalizar mensajes según la hora.
31. Valores que PHP interpreta como falso
En PHP no solamente false se considera falso.
También hay otros valores que, en una condición, PHP puede interpretar como falsos.
Algunos de los más importantes son:
Valor
PHP lo interpreta como
false
falso
0
falso
"0"
falso
""
falso
null
falso
[]
falso
Ejemplo:
<?php
$nombre = "";
if ($nombre) { echo "El nombre tiene contenido."; } else { echo "El nombre está vacío."; }
?>
Como $nombre contiene una cadena vacía, PHP la interpreta como falso.
Resultado:
El nombre está vacío.
Sin embargo, para alumnos que están empezando, muchas veces es más claro escribir condiciones explícitas:
<?php
$nombre = "";
if ($nombre !== "") { echo "El nombre tiene contenido."; } else { echo "El nombre está vacío."; }
?>
Este segundo ejemplo deja más claro qué estamos comprobando.
32. Ejemplo práctico completo: acceso a una zona privada
Vamos a unir varias ideas en un ejemplo más completo.
Queremos comprobar:
El usuario debe haber iniciado sesión. La cuenta debe estar activa. El rol debe ser admin o editor.
if (!$sesionIniciada) { echo "Debes iniciar sesión."; } elseif (!$cuentaActiva) { echo "Tu cuenta no está activa."; } elseif ($rol === "admin" || $rol === "editor") { echo "Puedes acceder a la zona privada."; } else { echo "No tienes permisos suficientes."; }
?>
Este código está escrito de forma ordenada.
Primero comprobamos los errores principales:
Si no hay sesión, no dejamos continuar. Si la cuenta no está activa, tampoco. Si todo lo anterior está bien, miramos los permisos. Finalmente, si no tiene el rol adecuado, denegamos el acceso.
Este patrón es muy habitual en programación web.
33. Ejemplo práctico completo: carrito de compra
Vamos a imaginar que tenemos una tienda online sencilla.
Queremos comprobar si un producto se puede comprar.
if ($stock <= 0) { echo "El producto $producto está agotado."; } elseif (!$usuarioRegistrado) { echo "Debes iniciar sesión para comprar."; } else { echo "Puedes comprar $producto por $precio euros."; }
?>
Resultado:
El producto Monitor 24 pulgadas está agotado.
Fíjate en que, si el producto está agotado, ya no tiene sentido comprobar si el usuario está registrado. PHP entra en el primer bloque y termina la estructura condicional.
34. Ejemplo práctico completo: cálculo de descuento
Vamos a crear un pequeño sistema de descuentos.
Si el cliente compra más de 100 euros, tiene un 10% de descuento. Si compra más de 200 euros, tiene un 20% de descuento. Si compra 100 euros o menos, no tiene descuento.
Total inicial: 250 euros Descuento aplicado: 20% Importe descontado: 50 euros Total final: 200 euros
El orden aquí también importa. Primero comprobamos la condición más alta:
$totalCompra > 200
Si empezáramos por $totalCompra > 100, una compra de 250 euros entraría ahí y solo recibiría un 10% de descuento.
35. Ejemplo práctico completo: reserva de habitación
Imaginemos una aplicación muy sencilla para reservar una habitación.
Queremos comprobar:
Que hay habitaciones disponibles. Que el cliente ha indicado número de noches. Que el número de noches es válido. Que el cliente acepta las condiciones.
if ($habitacionesDisponibles <= 0) { echo "No hay habitaciones disponibles."; } elseif ($noches <= 0) { echo "Debes indicar un número de noches válido."; } elseif (!$aceptaCondiciones) { echo "Debes aceptar las condiciones de la reserva."; } else { $precioTotal = $noches * $precioPorNoche;
Este ejemplo es interesante porque dentro del else no solo mostramos un mensaje, sino que hacemos un cálculo.
Esto es habitual: primero validamos, después procesamos.
36. Ejemplo práctico completo: panel según rol de usuario
Una web puede mostrar opciones diferentes dependiendo del tipo de usuario.
<?php
$rol = "admin";
if ($rol === "admin") { echo "<h2>Panel de administración</h2>"; echo "<p>Puedes gestionar usuarios, productos y reservas.</p>"; } elseif ($rol === "editor") { echo "<h2>Panel de edición</h2>"; echo "<p>Puedes crear y modificar contenidos.</p>"; } elseif ($rol === "cliente") { echo "<h2>Zona de cliente</h2>"; echo "<p>Puedes consultar tus pedidos y modificar tus datos.</p>"; } else { echo "<h2>Acceso limitado</h2>"; echo "<p>No se reconoce tu rol de usuario.</p>"; }
?>
Aquí PHP no solo toma una decisión lógica, también genera HTML diferente según el caso.
Este es uno de los motivos por los que PHP se usa tanto en desarrollo web: puede mezclar lógica del servidor con generación dinámica de contenido HTML.
37. Alternar PHP y HTML en condicionales
También podemos escribir condicionales mezclando PHP y HTML de otra forma.
<?php if ($usuarioRegistrado): ?> <h1>Bienvenido a tu cuenta</h1> <p>Desde aquí puedes gestionar tus datos.</p> <?php else: ?> <h1>Acceso no permitido</h1> <p>Debes iniciar sesión para ver esta página.</p> <?php endif; ?>
</body> </html>
Esta sintaxis alternativa es bastante usada en plantillas PHP, porque puede resultar más legible cuando hay mucho HTML.
En lugar de abrir y cerrar llaves {}, usamos:
<?php if (condicion): ?> HTML <?php else: ?> HTML <?php endif; ?>
No es obligatorio usarla, pero conviene conocerla porque aparece en muchos proyectos PHP y en plantillas de WordPress.
38. Otro ejemplo con HTML: mostrar un aviso de stock
Este ejemplo representa una situación muy real. En una tienda online no queremos mostrar el mismo botón si el producto está disponible que si está agotado.
39. Condicionales y seguridad básica
Los condicionales también ayudan a proteger partes de una aplicación.
Por ejemplo, podemos impedir que un usuario no identificado vea una página privada.
<?php
$logueado = false;
if (!$logueado) { echo "No tienes permiso para acceder a esta página."; exit; }
echo "Contenido privado de la aplicación.";
?>
La función exit detiene la ejecución del script.
Esto significa que si el usuario no está logueado, PHP muestra el mensaje y deja de ejecutar el resto del archivo.
Más adelante, cuando trabajemos con sesiones, este tipo de código será muy habitual:
<?php
session_start();
if (!isset($_SESSION["usuario"])) { echo "Debes iniciar sesión."; exit; }
echo "Bienvenido a la zona privada.";
?>
En este ejemplo todavía aparecen elementos que se estudiarán más adelante, como session_start() y $_SESSION, pero la idea principal ya se entiende: usamos un condicional para proteger una parte del programa.
40. isset() y empty()
PHP tiene funciones muy utilizadas para comprobar variables.
La función isset() comprueba si una variable existe y no es null.
Ejemplo:
<?php
if (isset($_POST["nombre"])) { echo "El campo nombre ha sido enviado."; } else { echo "El campo nombre no existe."; }
?>
La función empty() comprueba si una variable está vacía.
Ejemplo:
<?php
$nombre = "";
if (empty($nombre)) { echo "El nombre está vacío."; } else { echo "El nombre tiene contenido."; }
?>
Hay que tener cuidado con empty(), porque considera vacíos varios valores, como "", 0, "0", null, false o [].
Ejemplo:
<?php
$stock = 0;
if (empty($stock)) { echo "No hay stock o el valor está vacío."; }
?>
Aunque $stock existe y vale 0, empty() lo considera vacío.
Por eso, en algunos casos es mejor hacer comprobaciones explícitas:
<?php
$stock = 0;
if ($stock === 0) { echo "El producto está agotado."; }
?>
La idea importante es esta: no basta con saber que una función existe; hay que saber exactamente qué está comprobando.
41. Ejemplo práctico: validar un formulario de login
if ($nombre === "") { echo "El nombre es obligatorio."; } elseif ($email === "") { echo "El email es obligatorio."; } elseif (!filter_var($email, FILTER_VALIDATE_EMAIL)) { echo "El email no tiene un formato válido."; } elseif ($password === "") { echo "La contraseña es obligatoria."; } elseif (strlen($password) < 6) { echo "La contraseña debe tener al menos 6 caracteres."; } elseif ($password !== $repetirPassword) { echo "Las contraseñas no coinciden."; } elseif (!$aceptaCondiciones) { echo "Debes aceptar las condiciones."; } else { echo "Registro completado correctamente."; }
?>
Aquí aparecen dos funciones útiles:
filter_var($email, FILTER_VALIDATE_EMAIL)
Sirve para comprobar si un email tiene un formato válido.
strlen($password)
Devuelve la longitud de una cadena de texto.
Este ejemplo es muy representativo de cómo se trabaja en aplicaciones web: recogemos datos, comprobamos condiciones y, si todo es correcto, continuamos.
43. Ejemplo práctico: mostrar errores acumulados
En el ejemplo anterior solo mostramos el primer error encontrado. Eso está bien para empezar, pero en una aplicación real puede interesarnos mostrar todos los errores a la vez.
if ($nombre === "") { $errores[] = "El nombre es obligatorio."; }
if ($email === "") { $errores[] = "El email es obligatorio."; } elseif (!filter_var($email, FILTER_VALIDATE_EMAIL)) { $errores[] = "El email no tiene un formato válido."; }
if ($password === "") { $errores[] = "La contraseña es obligatoria."; } elseif (strlen($password) < 6) { $errores[] = "La contraseña debe tener al menos 6 caracteres."; }
if (count($errores) > 0) { echo "<h2>Se han encontrado errores:</h2>";
Cuando trabajamos con rangos, hay que prestar mucha atención a los límites.
Por ejemplo:
$temperatura <= 15
incluye el valor 15.
Mientras que:
$temperatura < 15
no lo incluiría.
48. Ejemplo práctico: recomendador sencillo
Podemos usar condicionales para crear un recomendador muy simple.
<?php
$presupuesto = 800; $uso = "programacion";
if ($presupuesto < 500) { echo "Te recomendamos un equipo básico para tareas de oficina y navegación."; } elseif ($presupuesto <= 1000 && $uso === "programacion") { echo "Te recomendamos un portátil con buen procesador y al menos 16 GB de RAM."; } elseif ($presupuesto <= 1000 && $uso === "videojuegos") { echo "Te recomendamos buscar un equipo con tarjeta gráfica dedicada."; } elseif ($presupuesto > 1000 && $uso === "programacion") { echo "Puedes optar por un equipo potente para desarrollo, máquinas virtuales y Docker."; } else { echo "Necesitamos más información para hacer una recomendación."; }
?>
Este ejemplo combina comparación numérica y comparación de cadenas.
49. Errores comunes al trabajar con condicionales
Uno de los errores más habituales es usar = en vez de == o ===.
Esto está mal:
<?php
$usuario = "cliente";
if ($usuario = "admin") { echo "Eres administrador."; }
?>
El operador = no compara. El operador = asigna.
Es decir, en vez de comprobar si $usuario es "admin", estamos cambiando el valor de $usuario.
La comparación correcta sería:
<?php
$usuario = "cliente";
if ($usuario === "admin") { echo "Eres administrador."; } else { echo "No eres administrador."; }
?>
Otro error habitual es olvidar las llaves:
<?php
$edad = 20;
if ($edad >= 18) echo "Eres mayor de edad."; echo "Puedes acceder.";
?>
Aunque visualmente pueda parecer que las dos líneas dependen del if, realmente solo la primera instrucción depende de la condición.
Por eso es mejor usar siempre llaves:
<?php
$edad = 20;
if ($edad >= 18) { echo "Eres mayor de edad."; echo "Puedes acceder."; }
?>
Esto evita errores y mejora la lectura.
50. Buenas prácticas con condicionales
Aunque los condicionales son sencillos de entender, conviene usarlos con orden.
Es recomendable escribir condiciones claras y fáciles de leer. Si una condición se vuelve demasiado larga, podemos guardarla en una variable.
if ($noches <= 0) { echo "El número de noches no es válido."; } elseif ($precioPorNoche <= 0) { echo "El precio por noche no es válido."; } else { $precioBase = $noches * $precioPorNoche;
Este ejemplo es bastante completo porque combina validación, cálculos y decisiones.
Ejercicios propuestos
Ejercicio 1: mayoría de edad
Crea un script PHP que guarde una edad en una variable y muestre si la persona es menor o mayor de edad.
Después modifica el programa para que también indique si la edad no es válida cuando sea menor que 0.
Ejercicio 2: nota de un alumno
Crea un programa que reciba una nota y muestre:
Suspenso si es menor que 5. Aprobado si está entre 5 y 6.99. Notable si está entre 7 y 8.99. Sobresaliente si está entre 9 y 10. Nota no válida si está fuera del rango de 0 a 10.
Ejercicio 3: login sencillo
Crea dos variables:
$usuario = "admin"; $password = "1234";
Después crea un condicional que compruebe si el usuario y la contraseña son correctos.
El programa debe comprobar si el producto tiene stock y si el usuario está registrado.
Si todo es correcto, debe mostrar que el producto se puede comprar.
Si no hay stock, debe indicar que el producto está agotado.
Si el usuario no está registrado, debe indicar que debe iniciar sesión.
Ejercicio 5: roles de usuario
Crea una variable $rol con uno de estos valores:
"admin" "editor" "cliente" "invitado"
Usa condicionales para mostrar un mensaje diferente según el rol.
Después repite el ejercicio usando switch.
Ejercicio 6: formulario de contacto
Crea un formulario HTML con los campos:
Nombre. Email. Mensaje.
Después crea un archivo PHP que valide:
Que el nombre no esté vacío. Que el email no esté vacío. Que el email tenga formato válido. Que el mensaje tenga al menos 10 caracteres.
Si todo es correcto, debe mostrar:
Formulario enviado correctamente
Resumen del tema
Los condicionales permiten que un programa tome decisiones.
La estructura más básica es if.
Cuando queremos ejecutar una alternativa usamos else.
Cuando tenemos varias posibilidades usamos elseif.
Para comparar una variable con muchos valores posibles podemos usar switch o match.
Los operadores de comparación permiten comprobar igualdad, diferencia, mayor que, menor que, etc.
Los operadores lógicos permiten combinar condiciones usando &&, || y !.
En PHP es importante diferenciar entre == y ===.
Los condicionales son fundamentales para validar formularios, controlar accesos, calcular descuentos, mostrar contenido según el usuario y proteger zonas privadas.
A partir de este punto, PHP deja de ser una simple secuencia de instrucciones y empieza a comportarse como un programa capaz de reaccionar ante distintas situaciones.
En programación hay muchas situaciones en las que necesitamos repetir una misma acción varias veces. Por ejemplo, mostrar los números del 1 al 10, recorrer una lista de productos, leer los datos de varios alumnos, calcular el total de un carrito o mostrar las filas de una tabla HTML.
Podríamos escribir el mismo código muchas veces, pero sería una mala solución. El código sería largo, difícil de mantener y muy propenso a errores. Para solucionar esto existen los bucles, también llamados estructuras repetitivas.
Un bucle permite ejecutar un bloque de código mientras se cumpla una condición o durante un número determinado de repeticiones.
En PHP trabajaremos principalmente con estas estructuras:
while
do while
for
foreach
Además, veremos instrucciones como break y continue, que nos permiten modificar el comportamiento normal de un bucle.
1. ¿Qué es un bucle?
Un bucle es una estructura que repite un bloque de instrucciones.
Imagina que queremos mostrar los números del 1 al 5.
Podríamos hacerlo así:
<?php echo 1; echo 2; echo 3; echo 4; echo 5; ?>
Funciona, pero no es práctico. Si tuviéramos que mostrar los números del 1 al 100, tendríamos que escribir cien líneas. Y si mañana queremos mostrar hasta el 1000, el problema sería todavía peor.
Con un bucle podemos hacerlo de forma mucho más limpia:
Mientras $numero sea menor o igual que 5, muestra el número y luego súmale 1.
El resultado será:
1 2 3 4 5
La clave de los bucles es entender que el programa no avanza simplemente de arriba hacia abajo una sola vez, sino que vuelve hacia atrás para repetir una parte del código.
2. Partes importantes de un bucle
Aunque cada tipo de bucle se escribe de forma diferente, casi todos tienen tres elementos importantes:
Primero, una variable de control, que normalmente sirve para contar o recorrer datos.
Segundo, una condición, que decide si el bucle debe seguir ejecutándose.
Tercero, una actualización, que modifica la variable de control para que el bucle pueda avanzar y terminar en algún momento.
El bucle empieza comprobando la condición. Si la condición es verdadera, entra dentro del bloque. Cuando termina el bloque, vuelve a comprobar la condición. Si sigue siendo verdadera, repite. Cuando la condición deja de cumplirse, el bucle termina.
Este ejemplo todavía está simplificado porque el intento está escrito directamente en el código. Más adelante podríamos recibir el valor desde un formulario usando $_POST.
Lo importante aquí es ver que el bucle puede depender de más de una condición.
La condición es:
$intento != $passwordCorrecta && $intentos < 3
Esto significa:
Mientras la contraseña sea incorrecta y queden intentos disponibles, el bucle podría repetirse.
4. El bucle do while
El bucle do while se parece mucho al while, pero tiene una diferencia muy importante.
En un while, primero se comprueba la condición y después se ejecuta el código.
En un do while, primero se ejecuta el código y después se comprueba la condición.
Su estructura es:
do { // Código que se repite } while (condición);
Observa que al final lleva punto y coma.
Ejemplo:
<?php $numero = 1;
do { echo "Número: " . $numero . "<br>"; $numero++; } while ($numero <= 5); ?>
El resultado será el mismo que antes:
Número: 1 Número: 2 Número: 3 Número: 4 Número: 5
La diferencia aparece cuando la condición inicialmente es falsa.
Diferencia entre while y do while
Ejemplo con while:
<?php $numero = 10;
while ($numero <= 5) { echo "Este mensaje no se muestra"; } ?>
Este código no muestra nada, porque la condición se comprueba antes de entrar.
Ahora el mismo caso con do while:
<?php $numero = 10;
do { echo "Este mensaje se muestra una vez"; } while ($numero <= 5); ?>
Aunque la condición es falsa, el bloque se ejecuta una vez antes de comprobarla.
Esto hace que do while sea útil cuando queremos que algo ocurra al menos una vez.
Ejemplo práctico: menú de opciones
Un caso típico de do while es un menú. Queremos mostrar el menú al menos una vez, y luego repetirlo si el usuario no elige salir.
En un programa de consola tendría mucho sentido. En PHP web no se usa exactamente igual porque las páginas web funcionan por peticiones, pero como ejercicio de lógica es muy útil.
<?php $opcion = 1;
do { echo "Menú principal<br>"; echo "1. Ver productos<br>"; echo "2. Ver carrito<br>"; echo "3. Salir<br><br>";
echo "Has elegido la opción: " . $opcion . "<br>";
$opcion++;
} while ($opcion <= 3); ?>
Este ejemplo simula que la opción va cambiando. Más adelante, cuando se trabaje con formularios o aplicaciones de consola, el valor podría venir del usuario.
5. El bucle for
El bucle for se utiliza mucho cuando sabemos cuántas veces queremos repetir algo.
Su estructura es:
for (inicio; condición; actualización) { // Código que se repite }
Los bucles y los condicionales se combinan constantemente.
Por ejemplo, podemos recorrer los números del 1 al 10 e indicar cuáles son pares y cuáles son impares.
<?php for ($i = 1; $i <= 10; $i++) { if ($i % 2 == 0) { echo $i . " es par<br>"; } else { echo $i . " es impar<br>"; } } ?>
El operador % calcula el resto de una división.
Si un número dividido entre 2 tiene resto 0, es par.
$i % 2 == 0
Este tipo de combinación es fundamental. Un bucle permite recorrer datos. Un condicional permite tomar decisiones sobre cada dato.
Ejemplo práctico: notas de alumnos
Supongamos que tenemos varias notas y queremos mostrar si cada una está aprobada o suspensa.
De momento usaremos un array sencillo. Aunque los arrays se estudien en profundidad más adelante, este ejemplo ayuda a entender muy bien la utilidad de los bucles.
Este ejemplo es muy parecido a lo que haríamos en una tienda online.
Cada producto tiene varios datos. El foreach exterior recorre todos los productos. En cada vuelta, la variable $producto contiene un producto completo.
Esta técnica se utiliza muchísimo: sumar precios, contar aprobados, calcular estadísticas, acumular puntos, contar errores, calcular importes de reservas, etc.
12. Contadores y acumuladores
En los bucles aparecen dos conceptos muy importantes: contador y acumulador.
Un contador normalmente suma de uno en uno. Sirve para contar cuántas veces ocurre algo.
Un acumulador va guardando una suma total o un resultado progresivo.
Ejemplo:
<?php $notas = [8, 4, 6, 3, 9, 5];
$aprobados = 0; $sumaNotas = 0;
foreach ($notas as $nota) { $sumaNotas = $sumaNotas + $nota;
if ($nota >= 5) { $aprobados++; } }
$media = $sumaNotas / count($notas);
echo "Aprobados: " . $aprobados . "<br>"; echo "Media de la clase: " . $media; ?>
En este ejemplo:
$aprobados es un contador.
$sumaNotas es un acumulador.
La variable $aprobados solo aumenta cuando la nota es mayor o igual que 5.
La variable $sumaNotas suma todas las notas.
13. break: salir de un bucle
La instrucción break permite terminar un bucle antes de que se cumpla su final normal.
Ejemplo:
<?php for ($i = 1; $i <= 10; $i++) { if ($i == 5) { break; }
echo $i . "<br>"; } ?>
Resultado:
1 2 3 4
Cuando $i vale 5, se ejecuta break y el bucle termina inmediatamente.
El producto "Ratón" no se muestra porque no tiene stock.
15. Bucles anidados
Un bucle anidado es un bucle dentro de otro bucle.
Esto puede parecer complicado al principio, pero es muy útil para trabajar con tablas, matrices, calendarios, tableros de juego o estructuras de filas y columnas.
Este ejemplo resume muy bien para qué sirven los bucles en PHP. No se trata solo de repetir código. Se trata de recorrer datos, analizarlos, tomar decisiones y construir una salida útil para el usuario.
30. Conclusión
Los bucles son una de las herramientas más importantes de cualquier lenguaje de programación. En PHP son especialmente útiles porque muchas veces necesitamos generar HTML a partir de datos.
Con un bucle podemos mostrar listas, construir tablas, recorrer productos, calcular totales, validar información o analizar conjuntos de datos.
El while es útil cuando dependemos de una condición.
El do while garantiza que el bloque se ejecute al menos una vez.
El for es ideal cuando sabemos cuántas veces queremos repetir.
El foreach es la herramienta principal para recorrer arrays.
Dominar los bucles es un paso fundamental antes de avanzar hacia arrays más complejos, formularios, bases de datos y aplicaciones web completas.
Cuando empezamos a crear páginas web con PHP, es habitual que al principio cada archivo tenga todo su código escrito dentro del mismo documento. Por ejemplo, podemos tener una página index.php, otra llamada contacto.php, otra llamada productos.php y otra llamada servicios.php. Cada una de ellas puede tener su propio HTML completo, con su cabecera, su menú, su contenido principal y su pie de página.
El problema aparece cuando varias páginas comparten partes iguales. Imaginemos que todas las páginas tienen el mismo menú de navegación. Si escribimos ese menú directamente en cada archivo, estaremos repitiendo el mismo código una y otra vez. Esto puede parecer cómodo al principio, pero en cuanto el proyecto crece se convierte en un problema.
Por ejemplo, si queremos añadir una nueva opción al menú, tendríamos que modificar manualmente todos los archivos del sitio web. Si tenemos cuatro páginas, todavía es manejable. Pero si tenemos veinte, cincuenta o cien páginas, mantener ese código repetido se vuelve lento, incómodo y muy propenso a errores.
Para solucionar este problema, PHP nos permite separar partes comunes del código en archivos independientes y después insertarlas donde las necesitemos. Para eso usamos principalmente las instrucciones include y require.
Estas instrucciones permiten cargar el contenido de un archivo dentro de otro. Dicho de forma sencilla, PHP lee el archivo indicado y coloca su contenido justo en el punto donde hemos escrito el include o el require.
Esto es especialmente útil para crear partes reutilizables de una página web, como:
La cabecera HTML.
El menú de navegación.
El pie de página.
Barras laterales.
Formularios comunes.
Bloques de conexión a bases de datos.
Configuraciones compartidas.
En este tema vamos a centrarnos en el uso más inicial y visual: reutilizar fragmentos HTML comunes en varias páginas PHP.
El problema del código repetido
Supongamos que tenemos una página sencilla llamada index.php.
Si observamos los tres archivos, vemos que hay mucho código repetido. La cabecera, el menú y el pie de página aparecen una y otra vez.
Esto no es una buena práctica. Si queremos cambiar el título principal del sitio, modificar el menú o actualizar el pie de página, tendremos que hacerlo en todos los archivos.
La solución consiste en separar esas partes comunes en archivos independientes.
Qué es include
La instrucción include permite insertar el contenido de un archivo dentro de otro archivo PHP.
Su estructura básica es la siguiente:
include "archivo.php";
Cuando PHP encuentra esta línea, intenta buscar el archivo indicado y colocar su contenido en ese punto exacto.
Por ejemplo:
include "menu.php";
Esto significa que PHP cargará el archivo menu.php y mostrará su contenido justo donde aparece el include.
Crear un archivo común para el menú
Vamos a separar el menú de navegación en un archivo independiente.
Este archivo no necesita tener una estructura HTML completa. No necesita <!DOCTYPE html>, ni <html>, ni <head>, ni <body>, porque no representa una página completa. Solo contiene una parte de la página.
Ahora, si queremos modificar el menú, solo tenemos que cambiar el archivo menu.php. Todas las páginas que lo incluyan mostrarán automáticamente el menú actualizado.
Separar también la cabecera y el pie de página
El menú no es la única parte que podemos reutilizar. También podemos separar la cabecera y el pie.
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title>Mi página web</title>
</head>
<body>
<?php include "header.php"; ?>
<?php include "menu.php"; ?>
<main>
<h2>Página de inicio</h2>
<p>Bienvenido a mi página web.</p>
</main>
<?php include "footer.php"; ?>
</body>
</html>
La página sigue funcionando igual, pero ahora está mejor organizada. Cada parte común está en su propio archivo.
Esta forma de trabajar es muy habitual en proyectos web. Permite dividir una página en piezas pequeñas, más fáciles de entender, mantener y reutilizar.
Una estructura básica de carpetas
Cuando un proyecto empieza a crecer, conviene organizar los archivos en carpetas.
Podemos crear una carpeta llamada includes para guardar los fragmentos comunes.
En este caso, como los archivos comunes están dentro de la carpeta includes, tenemos que indicar la ruta correctamente.
En index.php escribiríamos:
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<?php include "includes/footer.php"; ?>
La página completa quedaría así:
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title>Mi página web</title>
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2>Página de inicio</h2>
<p>Bienvenido a mi página web.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
Es importante entender que la ruta del archivo incluido depende de dónde se encuentra el archivo que está haciendo el include.
Si index.php está en la raíz del proyecto y header.php está dentro de la carpeta includes, la ruta correcta será:
include "includes/header.php";
Qué ocurre si el archivo no existe
Si usamos include y el archivo indicado no existe, PHP mostrará un aviso, pero intentará seguir ejecutando el resto de la página.
Por ejemplo:
<?php include "includes/cabecera.php"; ?>
Si el archivo cabecera.php no existe, PHP generará un mensaje de advertencia similar a este:
Warning: include(includes/cabecera.php): Failed to open stream...
Aunque aparezca el aviso, PHP intentará continuar con el resto del documento.
Esto puede ser útil en algunos casos, pero también puede ser peligroso si el archivo incluido es fundamental para que la página funcione correctamente.
Qué es require
La instrucción require también sirve para insertar el contenido de un archivo dentro de otro. Su uso es muy parecido al de include.
require "archivo.php";
La diferencia principal está en lo que ocurre si el archivo no se encuentra.
Con include, PHP muestra una advertencia y continúa ejecutando la página.
Con require, PHP muestra un error grave y detiene la ejecución.
Por ejemplo:
<?php require "includes/header.php"; ?>
Si el archivo existe, se carga normalmente. Pero si no existe, PHP detiene la página.
Esto tiene sentido cuando el archivo que estamos cargando es imprescindible.
Diferencia entre include y require
Aunque las dos instrucciones sirven para cargar archivos externos, no se comportan igual cuando hay un problema.
include se suele usar cuando el archivo que estamos cargando no es totalmente imprescindible. Si falla, la página puede seguir funcionando, aunque quizá no se muestre una parte concreta.
require se usa cuando el archivo es necesario para que la página funcione correctamente. Si el archivo no existe, lo mejor es detener la ejecución para evitar errores mayores.
Por ejemplo, en una página sencilla podríamos usar include para cargar un bloque visual como un aviso o una sección secundaria.
<?php include "includes/aviso.php"; ?>
Pero si en un proyecto más avanzado tenemos un archivo con la conexión a la base de datos, normalmente usaríamos require.
<?php require "includes/conexion.php"; ?>
En este tema estamos trabajando principalmente con HTML común, por lo que podemos empezar usando include. Más adelante, cuando trabajemos con configuración, sesiones, funciones o bases de datos, veremos que require puede ser más adecuado.
La palabra once significa “una vez”. Estas instrucciones cargan el archivo solo si no se ha cargado antes.
Esto es útil para evitar que el mismo archivo se incluya varias veces por error.
Por ejemplo:
<?php include_once "includes/menu.php"; ?>
Si el archivo menu.php ya se ha cargado antes, PHP no lo volverá a cargar.
Al principio, trabajando con cabeceras, menús y pies de página, normalmente nos bastará con include. Pero es importante conocer include_once y require_once, porque son muy habituales en proyectos más grandes.
Crear una plantilla básica reutilizable
Vamos a crear una estructura sencilla para una web con varias páginas.
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title>Inicio</title>
<link rel="stylesheet" href="css/estilos.css">
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2>Inicio</h2>
<p>Esta es la página principal de nuestro sitio web.</p>
<p>El encabezado, el menú y el pie de página se cargan desde archivos externos.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
Creamos también la página servicios.php.
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title>Servicios</title>
<link rel="stylesheet" href="css/estilos.css">
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2>Servicios</h2>
<p>En esta sección se mostrarían los servicios ofrecidos por la empresa o el proyecto.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
Y finalmente la página contacto.php.
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title>Contacto</title>
<link rel="stylesheet" href="css/estilos.css">
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2>Contacto</h2>
<p>Desde esta página se podría mostrar un formulario de contacto.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
Con esta estructura ya tenemos una pequeña web dividida en partes reutilizables.
Si ahora queremos añadir una opción nueva al menú, solo tenemos que editar includes/menu.php.
Ahora no tenemos que cambiar manualmente el año cada vez que empiece uno nuevo. PHP lo calculará automáticamente.
Esto demuestra una de las ventajas de usar archivos .php para nuestros bloques comunes: pueden combinar HTML y código PHP.
Usar variables antes de incluir un archivo
También podemos preparar una variable en la página principal y usarla dentro de un archivo incluido.
Por ejemplo, podemos crear una variable llamada $tituloPagina.
En index.php:
<?php
$tituloPagina = "Inicio";
?>
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title><?php echo $tituloPagina; ?></title>
<link rel="stylesheet" href="css/estilos.css">
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2><?php echo $tituloPagina; ?></h2>
<p>Bienvenido a la página principal.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
También podríamos usar esa variable dentro de header.php.
Archivo includes/header.php:
<header>
<h1>Mi sitio web con PHP</h1>
<p>Estás visitando la sección: <?php echo $tituloPagina; ?></p>
</header>
Cuando index.php incluye header.php, el archivo incluido puede acceder a la variable $tituloPagina, porque se está insertando dentro del mismo contexto de ejecución.
Esto es muy útil, pero también exige orden. Si una variable se usa dentro de un archivo incluido, debemos asegurarnos de que se ha creado antes de hacer el include.
Ejemplo con varias páginas y título dinámico
Podemos aplicar la misma idea en todas las páginas.
Archivo index.php:
<?php
$tituloPagina = "Inicio";
?>
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title><?php echo $tituloPagina; ?></title>
<link rel="stylesheet" href="css/estilos.css">
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2><?php echo $tituloPagina; ?></h2>
<p>Bienvenido a la página principal.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
También conviene usar nombres claros. Un archivo llamado header.php se entiende mejor que uno llamado parte1.php. Un archivo llamado menu.php se entiende mejor que uno llamado navegacion2.php.
Otra recomendación importante es no abusar de los includes. Separar el código ayuda, pero si dividimos demasiado una página en muchos archivos pequeños sin necesidad, el proyecto puede volverse confuso. La idea es separar aquello que realmente se repite o que tiene sentido mantener de forma independiente.
En esta etapa inicial, lo más recomendable es usar include para partes visuales comunes como header.php, menu.php y footer.php.
Más adelante, cuando empecemos a trabajar con funciones, configuración, sesiones o bases de datos, tendrá sentido usar require o require_once para archivos imprescindibles.
Resumen práctico
include y require permiten cargar un archivo dentro de otro archivo PHP.
La instrucción include intenta cargar el archivo y, si no lo encuentra, muestra una advertencia pero permite que la página continúe ejecutándose.
La instrucción require también carga un archivo, pero si no lo encuentra detiene la ejecución de la página.
En proyectos web, estas instrucciones son muy útiles para evitar repetir código. Podemos crear archivos comunes como header.php, menu.php y footer.php, e incluirlos en todas las páginas que los necesiten.
Gracias a esto, nuestro proyecto queda más limpio, más ordenado y más fácil de mantener.
Actividad propuesta
Crea una pequeña web en PHP con tres páginas:
index.php
servicios.php
contacto.php
La web debe tener una carpeta llamada includes con los siguientes archivos:
header.php
menu.php
footer.php
Cada página debe cargar esos archivos usando include.
Además, cada página debe tener un contenido principal diferente dentro de la etiqueta <main>.
Como ampliación, crea una variable $tituloPagina en cada página y úsala para mostrar el título correspondiente tanto en la etiqueta <title> como dentro del contenido principal.
Preguntas de reflexión
¿Por qué no es recomendable copiar y pegar el mismo menú en todas las páginas de un sitio web?
¿Qué ventaja tiene guardar el menú en un archivo independiente?
¿Qué diferencia hay entre include y require?
¿Qué ocurre si usamos include y el archivo no existe?
¿Qué ocurre si usamos require y el archivo no existe?
¿Para qué podría servir include_once?
¿Por qué es importante organizar correctamente las carpetas de un proyecto?
¿Qué problemas pueden aparecer si indicamos mal la ruta de un archivo incluido?
<?php
$tituloPagina = "Inicio";
?>
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title><?php echo $tituloPagina; ?></title>
<link rel="stylesheet" href="css/estilos.css">
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2><?php echo $tituloPagina; ?></h2>
<p>Esta es la página principal del proyecto.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
En servicios.php, escribe:
<?php
$tituloPagina = "Servicios";
?>
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title><?php echo $tituloPagina; ?></title>
<link rel="stylesheet" href="css/estilos.css">
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2><?php echo $tituloPagina; ?></h2>
<p>En esta página se describen los servicios ofrecidos.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
En contacto.php, escribe:
<?php
$tituloPagina = "Contacto";
?>
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title><?php echo $tituloPagina; ?></title>
<link rel="stylesheet" href="css/estilos.css">
</head>
<body>
<?php include "includes/header.php"; ?>
<?php include "includes/menu.php"; ?>
<main>
<h2><?php echo $tituloPagina; ?></h2>
<p>Desde esta página se podría contactar con el sitio web.</p>
</main>
<?php include "includes/footer.php"; ?>
</body>
</html>
Cuando hayas terminado, abre el proyecto desde un servidor local como XAMPP, MAMP o un contenedor con Apache y PHP. Comprueba que las tres páginas muestran la misma cabecera, el mismo menú y el mismo pie de página.
Después modifica el archivo menu.php añadiendo una nueva opción llamada Blog.
Importante Esta práctica está pensada para comprobar que el alumno tiene una base real en desarrollo web con PHP. No se busca una aplicación compleja. Se busca una aplicación simple, funcional, bien organizada y bien explicada.
¿Qué vais a hacer?
En esta práctica vais a desarrollar una pequeña aplicación web con:
una portada
una página con formulario
una página de listado
una base de datos MySQL
conexión con PHP usando mysqli
validación del formulario con JavaScript
Además del código, tendréis que entregar una documentación paso a paso explicando todo el proceso.
Objetivo de la práctica
El objetivo es construir una miniaplicación que permita registrar alumnos en una base de datos.
Cada registro deberá incluir como mínimo:
nombre
apellidos
email
curso
edad
La aplicación deberá permitir:
entrar en una portada,
acceder a un formulario,
validar los datos antes de enviarlos,
guardar esos datos en MySQL,
mostrar un listado con todos los registros guardados.
Qué debe tener la aplicación
Parte obligatoria
La aplicación debe incluir obligatoriamente:
una portada (index.php)
una página con formulario (formulario.php)
una página que procese el guardado (guardar.php)
una página de listado (listar.php)
una conexión a base de datos (conexion.php)
una validación con JavaScript (script.js)
una base de datos MySQL con una tabla
un archivo SQL con la creación de la base de datos y la tabla
Mejoras opcionales
Se valorará positivamente si añadís:
programación orientada a objetos
validación también en PHP
sesiones
login con contraseña
uso de password_hash()
consultas preparadas
edición de registros
borrado de registros
mejor diseño con CSS
Guía paso a paso
Paso 1. Crear la carpeta del proyecto
Cread una carpeta para guardar todos los archivos de la práctica.
Importante Aunque el proyecto sea pequeño, debéis mantener una estructura clara. Un proyecto desordenado suele dar problemas y también dificulta explicar el trabajo.
Paso 2. Crear la base de datos
Antes de empezar con PHP, debéis crear la base de datos y la tabla donde se guardarán los datos.
Script SQL de ejemplo
CREATE DATABASE practica_php; USE practica_php;CREATE TABLE alumnos ( id INT AUTO_INCREMENT PRIMARY KEY, nombre VARCHAR(50) NOT NULL, apellidos VARCHAR(100) NOT NULL, email VARCHAR(100) NOT NULL, curso VARCHAR(50) NOT NULL, edad INT NOT NULL );
Qué hace este script
crea una base de datos llamada practica_php
selecciona esa base de datos
crea una tabla llamada alumnos
define un campo id autoincremental
añade los campos del formulario
Qué debéis hacer vosotros
ejecutar el script
comprobar que la base de datos existe
comprobar que la tabla se ha creado correctamente
hacer una captura de pantalla
Ejemplo de explicación para la entrega
Primero he creado una base de datos llamada practica_php. Después he creado una tabla llamada alumnos, que servirá para almacenar los datos enviados desde el formulario. La tabla tiene un campo id como clave primaria y varios campos de texto y numéricos para guardar la información.
Paso 3. Crear la portada
La portada será la página inicial de la aplicación.
Debe incluir
un título
una breve descripción
un enlace al formulario
un enlace al listado
Ejemplo de index.php
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<title>Miniaplicación PHP</title>
<link rel="stylesheet" href="estilos.css">
</head>
<body>
<h1>Miniaplicación de registro de alumnos</h1>
<p>Esta aplicación permite guardar alumnos en una base de datos y mostrar su listado.</p>
<ul>
<li><a href="formulario.php">Ir al formulario</a></li>
<li><a href="listar.php">Ver listado</a></li>
</ul>
</body>
</html>
Qué debéis comprobar
la página carga sin errores
los enlaces funcionan
el texto se ve correctamente
Ejemplo de explicación para la entrega
He creado una portada en el archivo index.php para que la aplicación tenga una página inicial. En ella he añadido un título, una descripción breve y dos enlaces: uno al formulario y otro al listado.
Paso 4. Crear el formulario
Ahora debéis crear la página que permitirá introducir los datos.
action="guardar.php" indica a qué archivo se enviarán los datos
method="post" indica que los datos viajarán mediante POST
cada campo tiene name e id
el formulario tiene un id para poder validarlo con JavaScript
Importante Si un name está mal escrito, PHP no recibirá bien ese dato. Este es uno de los errores más comunes en este tipo de práctica.
Ejemplo de explicación para la entrega
En el archivo formulario.php he creado un formulario HTML con cinco campos. He usado el método POST para enviar los datos al archivo guardar.php, que será el encargado de procesarlos en PHP.
Paso 5. Validar el formulario con JavaScript
Antes de guardar los datos, debéis comprobar en el navegador que lo que el usuario ha escrito tiene sentido.
Debéis validar al menos
que no haya campos vacíos
que el email tenga formato válido
que la edad sea correcta
Ejemplo de script.js
document.addEventListener("DOMContentLoaded", function () {
const formulario = document.getElementById("formAlumno");
formulario.addEventListener("submit", function (e) {
const nombre = document.getElementById("nombre").value.trim();
const apellidos = document.getElementById("apellidos").value.trim();
const email = document.getElementById("email").value.trim();
const curso = document.getElementById("curso").value.trim();
const edad = document.getElementById("edad").value.trim();
if (nombre === "" || apellidos === "" || email === "" || curso === "" || edad === "") {
alert("Todos los campos son obligatorios.");
e.preventDefault();
return;
}
const patronEmail = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
if (!patronEmail.test(email)) {
alert("El email no tiene un formato válido.");
e.preventDefault();
return;
}
if (isNaN(edad) || edad < 1 || edad > 120) {
alert("La edad no es válida.");
e.preventDefault();
}
});
});
Qué debéis probar
dejar todos los campos vacíos
escribir un email incorrecto
escribir una edad no válida
rellenar todo correctamente
Ejemplo de explicación para la entrega
He creado un archivo script.js para validar el formulario antes del envío. Primero compruebo que no haya campos vacíos. Después reviso el formato del email mediante una expresión regular y, por último, valido que la edad sea numérica y esté en un rango lógico.
Importante La validación en JavaScript mejora la experiencia del usuario, pero no sustituye a la validación en servidor. Como mejora opcional, podéis validar también en PHP.
Paso 6. Crear la conexión a la base de datos
Ahora debéis preparar el archivo que conectará PHP con MySQL.
no hay errores de usuario, contraseña o nombre de base de datos
Ejemplo de explicación para la entrega
En conexion.php he definido las variables necesarias para conectarme a MySQL: servidor, usuario, contraseña y nombre de la base de datos. Después he usado new mysqli(...) para abrir la conexión y he añadido una comprobación para detectar errores.
Paso 7. Guardar los datos enviados
Aquí debéis recoger los datos del formulario y guardarlos en la tabla.
$_POST recoge los datos enviados por el formulario
INSERT INTO añade una fila nueva a la tabla
query() ejecuta la consulta SQL
si todo va bien, se muestra un mensaje de éxito
Ejemplo de explicación para la entrega
En guardar.php he recogido los valores enviados desde el formulario con $_POST. Después he creado una consulta INSERT para guardar esos datos en la tabla alumnos. Finalmente he ejecutado la consulta y he mostrado un mensaje de éxito si el guardado se ha realizado correctamente.
Importante Este ejemplo está hecho de forma simple para trabajar los fundamentos. Como mejora opcional, se valorará el uso de consultas preparadas.
Paso 8. Mostrar el listado de registros
Ahora debéis recuperar los datos de la tabla y mostrarlos en pantalla.
SELECT * FROM alumnos recupera todos los registros
query() ejecuta la consulta
fetch_assoc() devuelve una fila asociativa
el while recorre todas las filas
Ejemplo de explicación para la entrega
En listar.php he realizado una consulta SELECT para obtener todos los registros de la tabla alumnos. Después he usado un bucle while junto con fetch_assoc() para recorrer el resultado y mostrar cada alumno dentro de una tabla HTML.
Paso 9. Añadir un estilo básico
La parte visual no es lo principal, pero sí conviene que la aplicación tenga una presentación limpia.
He creado un archivo estilos.css para dar una presentación básica al proyecto. He aplicado una tipografía sencilla, un fondo claro y un estilo mínimo al formulario y a los campos de entrada.
Comprobaciones finales
Antes de entregar, revisad todo esto:
la portada carga correctamente
el formulario se muestra bien
la validación bloquea errores
los datos correctos se guardan
el listado muestra los registros
no hay enlaces rotos
la base de datos coincide con el código PHP
Qué debéis entregar
Debéis entregar un archivo comprimido .zip con esta estructura:
Que los archivos estén organizados y tengan sentido
Portada
Que exista, funcione y permita navegar
Formulario
Que tenga los campos pedidos y funcione
Validación JS
Que detecte errores básicos correctamente
Conexión con MySQL
Que use mysqli y funcione
Inserción de datos
Que los datos se guarden correctamente
Listado
Que se muestren todos los registros
Claridad del código
Que el código sea simple, comprensible y ordenado
Documentación
Que explique el proceso paso a paso
Mejoras opcionales
POO, sesiones, seguridad, edición, borrado, etc.
Plantilla completa de memoria para rellenar
A continuación tenéis una plantilla orientativa. Podéis seguir esta estructura para redactar vuestra memoria.
1. Portada
Título de la práctica: Miniaplicación web con PHP, MySQLi y JavaScript
Nombre y apellidos del alumno: [Escribir aquí]
Módulo: [Escribir aquí]
Fecha: [Escribir aquí]
2. Objetivo de la práctica
Ejemplo de redacción
El objetivo de esta práctica ha sido desarrollar una miniaplicación web en PHP conectada a una base de datos MySQL. La aplicación permite introducir datos de alumnos mediante un formulario, validarlos con JavaScript, guardarlos en la base de datos y mostrar posteriormente el listado de registros almacenados.
3. Descripción general del proyecto
Explicad qué archivos habéis creado y para qué sirve cada uno.
Ejemplo de redacción
El proyecto está compuesto por varios archivos. index.php actúa como portada. formulario.php contiene el formulario de entrada de datos. guardar.php procesa la información enviada y la guarda en la base de datos. listar.php muestra los registros. conexion.php establece la conexión con MySQL. script.js valida el formulario y estilos.css da formato básico a la aplicación.
4. Desarrollo paso a paso
4.1 Creación de la base de datos
Explicad:
el nombre de la base de datos
el nombre de la tabla
los campos creados
el script SQL utilizado
Ejemplo
Primero he creado una base de datos llamada practica_php. Después he creado una tabla llamada alumnos con un campo id autoincremental y cinco campos adicionales para almacenar nombre, apellidos, email, curso y edad.
4.2 Creación de la portada
Explicad:
qué contiene
por qué la habéis diseñado así
qué enlaces tiene
Ejemplo
He creado una página principal llamada index.php para que el usuario tenga un punto de entrada a la aplicación. En esta página he colocado un título, una breve descripción y enlaces al formulario y al listado.
4.3 Creación del formulario
Explicad:
qué campos tiene
qué tipo de datos se introducen
por qué habéis usado POST
Ejemplo
En formulario.php he añadido cinco campos: nombre, apellidos, email, curso y edad. He usado el método POST porque permite enviar los datos al servidor sin mostrarlos en la URL.
4.4 Validación con JavaScript
Explicad:
qué validaciones habéis hecho
qué errores queríais evitar
Ejemplo
He validado que los campos no estén vacíos, que el email tenga un formato correcto y que la edad sea un número válido. De este modo evito que lleguen a PHP datos claramente incorrectos.
4.5 Conexión con la base de datos
Explicad:
cómo funciona mysqli
qué datos necesita la conexión
cómo comprobáis errores
Ejemplo
Para conectar PHP con MySQL he usado mysqli. He indicado el servidor, el usuario, la contraseña y el nombre de la base de datos. Después he comprobado si la conexión producía algún error.
4.6 Guardado de datos
Explicad:
cómo llegan los datos a PHP
qué hace $_POST
qué consulta SQL habéis usado
Ejemplo
En guardar.php he recogido los datos enviados por el formulario con $_POST. Después he creado una consulta INSERT para guardar la información en la tabla alumnos.
4.7 Listado de registros
Explicad:
qué consulta habéis hecho
cómo se recorre el resultado
cómo se muestra en HTML
Ejemplo
En listar.php he usado una consulta SELECT * FROM alumnos para obtener todos los registros. Después he recorrido el resultado con fetch_assoc() dentro de un bucle while para mostrar cada alumno en una tabla HTML.
5. Capturas de pantalla
Debéis incluir capturas de:
base de datos creada
formulario en pantalla
error de validación
inserción correcta
listado funcionando
Ejemplo de cómo presentarlo
Captura 1. Creación de la base de datos [Insertar captura]
Captura 2. Formulario visible [Insertar captura]
Captura 3. Validación de campos vacíos [Insertar captura]
Captura 4. Registro guardado correctamente [Insertar captura]
Captura 5. Listado de alumnos [Insertar captura]
6. Pruebas realizadas
Aquí debéis explicar las pruebas que habéis hecho.
Ejemplo de redacción
He realizado varias pruebas para comprobar el funcionamiento de la aplicación. Primero he intentado enviar el formulario dejando campos vacíos, y la validación ha impedido el envío. Después he escrito un email incorrecto y también se ha bloqueado el formulario. Más tarde he introducido todos los datos correctamente y el registro se ha guardado en la base de datos. Finalmente he accedido a la página de listado y he comprobado que el alumno aparecía correctamente.
7. Problemas encontrados y soluciones
Esta parte es muy importante. No pongáis solo “ninguno” salvo que sea verdad de forma muy clara.
Ejemplo 1
Uno de los errores que encontré fue que PHP no recibía correctamente el valor del email. Revisando el formulario vi que el atributo name del campo no coincidía con la clave usada en $_POST. Después de corregirlo, el dato llegó correctamente.
Ejemplo 2
Al principio no se mostraban los registros en la tabla. El problema era que el nombre de la base de datos en conexion.php no coincidía con el creado en MySQL. Lo corregí y el listado empezó a funcionar.
8. Conclusión personal
Explicad qué habéis aprendido y qué os ha costado más.
Ejemplo de redacción
Con esta práctica he aprendido mejor cómo se conecta una aplicación PHP con una base de datos MySQL y cómo se relacionan el formulario, $_POST, el INSERT y el SELECT. La parte que más me costó fue comprender el flujo completo de datos desde el formulario hasta el listado, pero después de hacer varias pruebas lo entendí mejor.
Recomendaciones finales
Importante No intentéis hacer una aplicación enorme sin dominar primero lo básico. Es preferible una práctica sencilla, clara, funcionando bien y bien explicada, que una práctica más grande pero confusa.
Orden recomendado de trabajo
crear la base de datos
hacer la portada
hacer el formulario
validar con JavaScript
crear la conexión
guardar los datos
mostrar el listado
hacer capturas
redactar la memoria
Mejoras opcionales para subir nota
Si termináis la parte obligatoria, podéis añadir:
validación en servidor
clases en PHP
login
sesiones
consultas preparadas
edición de registros
borrado de registros
diseño visual mejorado
El objetivo real de esta práctica es que comprendáis el circuito básico de una aplicación web:
Python es un lenguaje no tipado. Por tanto, no es necesario (ni posible) definir los tipos de datos utilizados al declarar variables.
En general, en Python las variables se declaran en el momento en el que éstas van a usarse, por lo que la declaración va acompañada del valor que se asigna.
# El siguiente es un ejemplo de declaración de una variable.
a = 10
print("'a' vale:")
print(a)
print("")
a = "abcd"
print("Ahora 'a' vale:")
print(a)
Tipos de datos básicos (primitivos):
– int: Números enteros, positivos o negativos. Ejemplo:
– complex: Números complejos (con parte real e imaginaria). Ejemplo:
z = 2 + 3j
– bool: Valores lógicos: True o False. Ejemplo:
is_active = True
– str: Cadenas de texto. Ejemplo:
name = "Python"
Tipos de datos compuestos (colecciones):
– list: Lista ordenada, modificable y que puede contener elementos heterogéneos. Ejemplo:
numbers = [1, 2, 3, 4]
– tuple: Tupla ordenada, inmutable y que puede contener elementos heterogéneos. Ejemplo:
coordinates = (10, 20)
– dict: Diccionarios, que almacenan pares clave-valor. Ejemplo:
person = {"name": "Alice", "age": 25}
Función type()
Sin embargo es importante conocer cuál es el tipo real de los datos que estamos utilizando. Es posible conocer el tipo de cualquier variable (y objeto en general) usando la función type()
var_1 = 100
type(var_1)
Respuesta: int
var_1 = "abcd"
type(var_1)
Respuesta: str
Trabajando con números
En Python existen los siguientes tipos numéricos:
– integer: 10
– float: 10.0
– complex: 10+10j
Así es como se realizan operaciones matemáticas sencillas con Python:
# Suma a = 10 b = 5 resultado = a + b print(resultado) # Imprime 15
# Resta a = 10 b = 5 resultado = a - b print(resultado) # Imprime 5
# Multiplicación a = 10 b = 5 resultado = a * b print(resultado) # Imprime 50
# División a = 10 b = 5 resultado = a / b print(resultado) # Imprime 2.0
# Potencia a = 10 b = 2 resultado = a ** b print(resultado) # Imprime 100
# Módulo (resto de la división) a = 10 b = 3 resultado = a % b print(resultado) # Imprime 1
Resumen de las operaciones aritmeticas
En Python podemos realizar varios tipos de operaciones, a continuación podemos ver algunas de ellas.
x + y: sum of x and y
x - y: difference of x and y
x * y: product of x and y
z / y: quotient of x and y
x // y: (floored) quotient of x and y
x % y: remainder of x / y
-x: x negated
+x: x unchanged
abs(x): absolute value or magnitude of x
int(x): x converted to integer
long(x): x converted to long integer
float(x): x converted to floating point
complex(re,im): a complex number with real part re, imaginary part im. im defaults to zero.
c.conjugate(): conjugate of the complex number c. (Identity on real numbers)
divmod(x, y): _math.trunc(x) the pair (x // y, x % y)
pow(x, y): x to the power y
x ** y: x to the power y
Adicionalmente, los tipos int y float admiten las siguientes operaciones:
math.trunc(x): x truncated to Integral
round(x[, n]): x rounded to n digits, rounding ties away from zero. If n is omitted, it defaults to 0.
math.floor(x): the greatest integral float <= x
math.ceil(x): the least integral float >= x
Coversión de tipos
Si en una expresión aritmética intervienen diferentes tipos de número, Python convierte automáticamente al tipo más general, según el siguiente esquema:
**int -> float -> complex**
También es posible convertir tipos de manera explícita mediante casts explícitos, con la siguiente forma: {nombe_tipo}(variable)
# Trasformación a entero int(12.5) # Trasformación a valor en coma flotante float(12)
Trabajando con textos
Tipo string (cadenas de daracteres). Strings delimitados por comillas dobles.
cadena_a = "Hola" cadena_b = "Mundo"
# Uso del operador "+" para concatenar print(cadena_a + " " + cadena_b)
También es posible escribir strings multi-línea fácilmente
string_multi_1 = "Esto es un string escrito en \ dos líneas. En este caso el string se interpreta como una sóla línea." print(string_multi_1)
string_multi_2 = '''Triples comillas: esto es también es un string escrito en dos líneas. En este caso se conserva la separación en líneas original.''' print(string_multi_2)
string_multi_3 = """Triples comillas: Esto es también es un string escrito en dos líneas. En este caso se conserva la separación en líneas original.""" print(string_multi_3)
El resultado seria:
Esto es un string escrito en dos líneas. En este caso el string se interpreta como una sóla línea.
Triples comillas: esto es también es un string escrito
en dos líneas. En este caso se conserva la separación en líneas original.
Triples comillas: Esto es también es un string escrito
en dos líneas. En este caso se conserva la separación en líneas original.
Algunos caracteres deben ser ‘escapados’ para poder incluirse en un string. Los más frecuentes son los siguientes:
Character Hexadecimal Description
\a 0x07 Bell or alert
\b 0x08 Backspace
\cx Control-x
\C-x Control-x
\e 0x1b Escape
\f 0x0c Formfeed
\M-\C-x Meta-Control-x
\n 0x0a Newline
\nnn Octal notation, where n is in the range 0.7
\r 0x0d Carriage return
\s 0x20 Space
\t 0x09 Tab
\v 0x0b Vertical tab
\x Character x
\xnn Hexadecimal notation, where n is in the range 0.9, a.f, or A.F
Python es muy versatil a la hora de usar operadores, en el caso de los textos podemos aplicar lógica a la propia cadena String
+ Concatenation - Adds values on either side of the operator
* Repetition - Creates new strings, concatenating multiple copies of the same string
[] Slice - Gives the character from the given index
[ : ] Range Slice - Gives the characters from the given range
in Membership - Returns true if a character exists in the given string
not in Membership - Returns true if a character does not exist in the given string
r/R Raw String - Suppresses actual meaning of Escape characters. The syntax for raw strings is exactly
the same as for normal strings with the exception of the raw string operator, the letter "r," which
precedes the quotation marks.
The "r" can be lowercase (r) or uppercase (R) and must be placed immediately preceding the first Ç
quote mark.
f Format - Performs String formatting
Ejemplos:
"HOLA " * 5
#->HOLA HOLA HOLA HOLA HOLA
"J" not in "HOLA"
#-> True
name = "Antonio"
f"Mi nombre es {name}"
#-> Mi nombre es Antonio
Lectura por Teclado con Python
El comando input() en Python se utiliza para tomar entradas del usuario durante la ejecución de un programa. Permite pausar el programa y esperar a que el usuario ingrese texto, que luego se puede procesar o almacenar en una variable.
input(prompt)
prompt (opcional): Una cadena de texto que se muestra al usuario como mensaje. Es útil para indicar qué tipo de entrada se espera. Si no se proporciona, no se muestra ningún mensaje.
valor = input()
------------------------
Esto lo escribo yo mismo
# Con esto puedo hacer el típico mensaje de introduce un valor:
numero = input("Introduce un numero: ")
# De esta manera al usuario le aparecerá el mensaje de Introduce un valor
------------------------
Introduce un numero: 50
------------------------
# Si quiero hacer algo con el resultado obtenido de lo anterior, debo pasarle la opción int a la variable de antes:
numero = int(numero)
# Debo poner la variable = int(variable) y ahora ya se puede sumar o hacer lo que quiera:
numero + 50
-------------------------
100
-------------------------
# Si el usuario pone un número decimal, tenemos que poner float, en lugar de int:
numero = input("Introduce un numero con decimales: ")
# Aquí abajo indico que el usuario va a introducir un número con decimales:
numero = float(numero)
-------------------------
Introduce un numero con decimales: 12.5
-------------------------
# Y ya puedo operar con él sin problemas
numero + 10
# Con float puedo introducir números tanto enteros como decimales.
-------------------------
22.5
-------------------------
# También puedo hacer todo lo anterior en una misma línea a la vez, esta vez con número entero:
numero = float( input("Introduce un número decimal o entero: "))
-------------------------
Introduce un número decimal o entero: 20
-------------------------
numero + 40
-------------------------
60.0
-------------------------
# Y ahora lo mismo pero con número decimal:
numero = float( input("Introduce un número decimal o entero: "))
-------------------------
Introduce un número decimal o entero: 10.5
-------------------------
numero + 40
# Como vemos con lo anterior, tenemos la opción de usar números enteros y decimales
-------------------------
50.5
-------------------------
# También puedo hacer esto con nombres; y la variable Mario se me guarda en nombre
nombre = input("Introduce tu nombre: ")
-------------------------
Introduce tu nombre: Mario
-------------------------
nombre = input("Introduce tu nombre ")
apellido = input("Introduce tu apellido ")
edad = int(input("Introduce tu edad ")) # Para número entero
estatura = float(input("Introduce tu estatura ")) # Para número decimal
-------------------------
Introduce tu nombre Mario
Introduce tu apellido Álvarez
Introduce tu edad 26
Introduce tu estatura 1.77
-------------------------
Ejercicios
Ejercicio 1: Crea tres variables: una que guarde tu nombre, otra tu edad, y otra tu ciudad. Imprime los valores con un mensaje como: «Hola, mi nombre es [nombre], tengo [edad] años y vivo en [ciudad].»
Ejercicio 2: Declara una variable con tu edad. Luego usa esta variable para calcular cuántos días, horas y minutos has vivido (aproximadamente).
Ejercicio 3: Escribe un programa que pida al usuario su nombre y su comida favorita. Luego imprime un mensaje como: «Hola [nombre], me alegra saber que te gusta [comida favorita].»
Ejercicio 4: Declara una variable de cada tipo:
Un número entero (int), por ejemplo, 42.
Un número decimal (float), por ejemplo, 3.14.
Una cadena de texto (str), por ejemplo, «Hola».
Un valor booleano (bool), por ejemplo, True.
Imprime el valor y el tipo de cada variable con type().
Un programa sin decisiones es como un robot que solo sabe caminar recto hasta chocar contra una pared. Las estructuras condicionales permiten que el programa observe, compare, evalúe… y elija. Son el mecanismo que controla el flujo de ejecución, es decir, el orden en que el programa ejecuta instrucciones.
En términos simples:
Si ocurre A → haz X Si no ocurre A → haz Y
Ese pequeño esquema es el corazón de casi todo software: validaciones, menús, videojuegos, seguridad, IA, redes, sistemas operativos… todo decide constantemente.
¿Qué es una condición?
Una condición es una expresión que solo puede ser:
Las colecciones en Python son estructuras de datos diseñadas para almacenar grupos de información y manipularlos de forma eficiente. Son el equivalente a cajas especializadas: algunas mantienen el orden, otras eliminan duplicados, otras asocian claves con valores.
Python ofrece cuatro colecciones fundamentales:
Listas (list) → secuencias ordenadas y modificables
Tuplas (tuple) → secuencias ordenadas e inmutables
Conjuntos (set) → colecciones sin duplicados
Diccionarios (dict) → pares clave-valor
Elegir bien la colección correcta es una habilidad esencial. No es solo sintaxis: es pensamiento estructurado.
Listas (list)
Una lista es una colección ordenada y modificable que permite duplicados.
Una lista en Python es una estructura de datos ordenada, mutable y que permite duplicados.
Ordenada significa que mantiene el orden en el que insertas los elementos. Mutable significa que puedes modificarla después de crearla. Permite duplicados significa que puede contener el mismo valor varias veces.
Es la colección más utilizada en Python.
Crear una lista
mi_lista = [1, 2, 3, 4, 5]
También se puede crear vacía:
mi_lista = []
O usando el constructor:
mi_lista = list((1, 2, 3))
Características fundamentales
Mantienen el orden de inserción
Permiten cualquier tipo de dato
Admiten tipos mezclados
Son dinámicas (crecen y decrecen en tiempo de ejecución)