Diferencia entre revisiones de «Plantilla:PHP/InstruccionEscribir»

De WikiEducator
Saltar a: navegación, buscar
(secuencia de escape)
 
(53 revisiones intermedias por el mismo usuario no mostrado)
Línea 1: Línea 1:
== Funciones de salida==
 
*Construcciones básicas para salida de caracteres
 
*En PHP,en realidad no son funciones por lo que pueden ir sin paréntesis  (con o sin paréntesis):
 
# '''''echo'''''
 
# '''''print'''''
 
*Existen otras funciones que iremos viendo según avance el curso
 
</div>
 
 
 
<div class="slide">
 
<div class="slide">
<!--4---------------------------------->
+
==string==
 
+
*Antes de ver cómo escribir un string ([[#echo|echo]]), vamos a comentar los [[#string|string]].
===echo===
+
*Un [[#string|string]] es una cadena de caracteres.
*Es el uso más sencillo
+
*Para representarla encerraremos caracteres entre <span class=resaltado>comillas simples</span> o <span class=resaltado>commillas dobles</span>, que dependiendo de lo que contenga, puede tener diferentes comportameninto, como veremos posteriormente.
*Imprime una cadena como argumentos
+
*En la versión '''''sin paréntesis''''' , también puedes pasar una lista de argumentos.
+
 
<source lang=php>
 
<source lang=php>
<?php
+
"Esto es una cadena encerrada entre comillas dobles que tiene caracteres,
*echo “primer argumento”, “segundo argumento”, “tercer argumento”
+
números 12345 y algún caracter no letra como % & y = y cualquiera en principio será imprimible"
?>
+
</source>
 +
<source lang=php>
 +
'Esto es una cadena encerrada entre comillas dobles que tiene caracteres,
 +
números 12345 y algún caracter no letra como % & y = y cualquiera en principio será imprimible'
 
</source>
 
</source>
</div>
 
  
<div class="slide">
+
*Dentro de un string, además de caracteres imprimibles como en el ejemplo anterior, pero también hay caracteres que tienen un <span id="resaltado">significado especial</span>, y ahí será diferente usar comillas simples y comillas dobles.
<!--4---------------------------------->
+
;Caracteres especiales:
  
===print===
+
Los siguientes caracteres son especiales, esto implica que no se imprimirán y tendrán algún tipo de efecto con los caracteres que le siguen:
*Esta sentencia es igual en uso y funcionalidad que echo
+
{|
*Tiene dos diferencias con echo
+
!style="color:white;background:blue;"|Carácter
#Sólo puede aceptar un argumento
+
!style="color:white;background:blue;"| Significado
#Devuelve un valor booleano que representa si la sentencia ha tenido exito  o no
+
!style="color:white;background:blue;"| Ejemplo
</div>
+
!style="color:white;background:blue;"|Acción
<div class="slide">
+
|-
{{Quiz_Multiple_Choice
+
|size=2em style="text-align:center;width:150px;color:white;background:red;"|$
|title=Observa el siguiente código e indica si es o no correcto
+
|style="width:150px;color:white;background:green|Sintaxis simple de interpretacion de variable
|body=
+
|style="width:150px;color:white;background:red|$edad
*<source lang=php> echo 'hola caracola', 'hola','como estás';</source>
+
|Se sustituirá la variable por su valor en este caso por el valor de $edad
** Correcto
+
|-
*** Cierto, '''''echo''''' admite una lista de parámetros
+
|size=2em style="text-align:center;width:150px;color:white;background:red;"|\
** Incorrecto
+
|style="width:150px;color:white;background:green|Secuenca de escape
*** Revisa bien tu respuesta
+
|El carácter que le sigue será interpretado como una secuencia de escape (ver tabla posterior)
*<source lang=php> print 'hola caracola', 'hola','como estás';</source>
+
|-
** Correcto
+
|size=2em style="text-align:center;width:150px;color:white;background:red;"|{}
*** Revisa bien tu respuesta
+
|style="width:150px;color:white;background:green|Sintaxis compleja
** Incorrecto
+
|style="width:150px;color:white;background:red|${nota['maria']}
*** Cierto, '''''print''''' no permite un listado de parámetros
+
|Se realiza una doble interpretación en este caso para acceder a un elemento de un array
|mix=false
+
|}
|hint=
+
}}
+
</div>
+
  
 +
=====secuencia de escape=====
 +
;Caracteres especiales con \
 +
https://www.php.net/manual/es/regexp.reference.escape.php
 +
*<span style=color:green>Secuencias de escape</span>: hay caracteres no imprimibles que podemos querer representar, para ello usaremos la barra invertida '''''\'''''.
  
 +
{| class="wikitable"
 +
! Secuencia de escape !! Significado
 +
|-
 +
|\’
 +
|Comillas simples
 +
|-
 +
|\"
 +
| Comillas dobles
 +
|-
 +
|\\
 +
| Barra invertida
 +
|-
 +
|\n
 +
| Nueva linea (endl)
 +
|-
 +
|\r
 +
| Retorno
 +
|-
 +
|\t
 +
| Tabulación Horizontal
 +
|-
 +
|\v
 +
| Tabulación Vertical
 +
|-
 +
|\0 - \777
 +
|Código ascii(octal)
 +
|-
 +
|\x0 - \xFF
 +
|Código ascii (hexadecimal)
 +
|}
  
<div class='slide>
+
*Para especificar una cadena de caracteres posemos usar "", '' (más adelante veremos otras dos formas muy parecidas que son con el operador '''''<<<''''', conocidos como heredoc y newdoc)
===Comentarios ===
+
*Aquí hay una gran diferencia en usar las comillas dobles "", y utilizar las comillas simples ''
*Son ignorados por el intérprete, no generan instrucciones, pero se consideran parte del software
+
{{MRM_Puntos clave|Title=Comillas dobles|
*En php tengo 4 formas de hacer comentarios
+
;Interpretan los caracteres especiales:
<source lang=php>
+
*'''''$''''' Especifico una variable por sintaxis simple
<?php
+
*'''''\''''' [#secuencia de escape|Secuencia de espape]
/*
+
*'''''{$''''' Especifico una variable por sintaxis compleja (doble interpretación, usado para acceder a posiciones de un array asociativo o atributos de un objeto)
Este código no hace nada pero muestra
+
}}
la sintaxis de los comentarios
+
como este que ocupa varias líneas tipo lenguaje C o Java
+
*/
+
$miVariable= 8;// Esta parte de la línea se ignorará
+
$miVariable+= 8;# y esta parte de línea tambien
+
echo "Valor de la variable $miVariable";
+
//Este es otro comentario de una sola línea
+
#Este es otro modo de hacer comentarios tipo script de linux
+
/**
+
Este comentario permite insertar información
+
Para que luego phpDocumentor genere una página web
+
Con la información de mi código
+
*/
+
</source>
+
*Así como comentar las funciones como veremos
+
*Este código nos visualizará lo siguiente
+
<source lang=php>
+
Valor de la variable 16
+
</source>
+
El resto del código será ignorado
+
</div>
+
  
<div class='slide>
+
{{MRM_Puntos clave|Title=Comillas simples|
*Es bueno escribir al principio del script
+
;No interpreta los caracteres especiales, salvo:
<source lang=php>
+
* '''''<nowiki>\'</nowiki> '''''
<?php
+
* '''''<nowiki>\\</nowiki> '''''
/**
+
* User: Nombre y apellidos
+
* Date: 19/10/17
+
* Version: 17:40
+
*/
+
</source>
+
</div>
+
<div class="slide">
+
*Aquí tienes la referencia para ver las diferentes directivas para generar código
+
*Más adelante en el curso las veremos.
+
{{MRM_Recursos de la Web|
+
*Directivas para comentarios https://phpdoc.org/docs/latest/index.html
+
 
}}
 
}}
 +
 +
== Funciones de salida==
 +
*Construcciones básicas para salida de caracteres
 +
*En PHP,en realidad no son funciones por lo que pueden ir sin paréntesis  (con o sin paréntesis):
 +
;echo
 +
;print
 +
*Existen otras funciones que iremos viendo según avance el curso, pero podemos probar ahora
 +
;printf
 +
;print_r
 +
;var_dump
 
</div>
 
</div>
 
 
<div class="slide">
 
<div class="slide">
{{MRM_Actividad|Title=probando comentarios |
+
<!--4---------------------------------->
*Escribe la  siguiente función anterior en un fichero php
+
*Antes de continuar viendo [[#echo|echo]], vamos a presentar los valores '''''cadena de caracteres''''' o '''''string'''''
  
<source lang=php>
+
=== echo ===
function miFuncion($num1, $num2){
+
    if ($num1>$num2)
+
        return $num1;
+
    else
+
        return $num2;
+
</source>
+
Ahora justo en la línea de encima de función escribe
+
<source lang=php>
+
/**
+
</source>
+
*y luego presiona intro
+
*Te debería de quedar
+
<source lang=php>
+
/**
+
*
+
* @param type $num1
+
* @param type $num2
+
* @return type
+
*/
+
function miFuncion($num1, $num2){
+
    if ($num1>$num2)
+
        return $num1;
+
    else
+
        return $num2;
+
 
+
</source>
+
}}
+
</div>
+
  
===Dónde poner el código embebido===
+
*Es la función más sencilla para imprimir texto en PHP.
<br/>
+
*Imprime una cadena como argumento.
{{MRM_Pregunta|Dónde escribir código php|{{feedback|Dónde queramos que se ejecute algo}} }}
+
*En la versión sin paréntesis, también puedes pasar una lista de argumentos.
</div>
+
  
<div class="slide">
+
<source lang="php"> <?php echo "primer argumento", "segundo argumento", "tercer argumento"; ?> </source>
<hr  />
+
*Donde queramos que se ejecute algo
+
<hr/>
+
[[Imagen:codigoPHP.png|center|900px]]
+
*Se ejecuta como si fuera un solo programa
+
*A la hora de incluir php podemos se usa mucho la filosofía Modelo Vista /Controlador que veremos en otro tema
+
{{MRM_Resumen|Title=Modelo vista controlador|
+
*Trata de separar el código según su cometido, de forma muy resumida
+
*Hay acciones que realizan cálculos y obtienen resultados (Controlador
+
*Hay acciones que lo que hacen es visualziar valores (Vista)
+
*Hay acciones que se encargan de interactuar con la base de datos (Modelo)
+
}}
+
{{MRM_Puntos clave|Title=Empecemos aplicar el modelo vista controlador|
+
*Podemos llevar este criterio desde el principio siguiente el esquema siguiente
+
{{Plegable|hide|esqueleto MVC|
+
<source lang=html5>
+
<!-- Empecemos nuestro fichero escribiendo instrucciones php
+
Estas instrucciones realizarán cálculos y obtendrán valores
+
En ningúm momento generan salidas,
+
Trataremos de almacenar los valores en variables
+
-->
+
<?php
+
//instrucciones php
+
$variables = "Mensaje escrito desde php";
+
?>
+
<!--Ahora el código html-->
+
<!DOCTYPE html>
+
<html>
+
    <head>
+
        <meta charset="UTF-8">
+
        <title>probando php</title>
+
    </head>
+
    <body>
+
            <!--Dentro del html cuando necesitemos ver valores
+
                los escribiemo
+
                También puede ser que necesitemos instrucciones
+
                las escribimos, pero intentando escribir lo necesario.
+
                Esto es vista
+
            -->
+
        <h1> <?php echo $variable ?></h1>
+
    </body>
+
</html>
+
</source>
+
  
}}
+
; Secuencias de escape
}}
+
*Cuando escribimos texto con echo, este texto se envía al navegador o recurso que solicitó la página. El navegador se encarga de interpretar y renderizar el HTML generado.
</div>
+
<div class="slide">
+
  
 +
*Puedes usar '''secuencias de escape''' como '''\n''' para un salto de línea en la salida HTML, aunque esta no será visible directamente en el navegador, sino solo en el código fuente del HTML.
  
{{MRM_Ejemplo|Title=Programa para ver si un número es o no par|
+
; Etiquetas HTML
No te preocupes si no entiendes el código, lo iremos viendo
+
<source lang=php>
+
<?php
+
  
//-----------CONTROLADOR-----------------------------
+
*Si se incluyen etiquetas HTML con echo, estas se enviarán tal cual al navegador, que las renderizará correctamente.
//Instrucciones que realizan cálculos
+
//Guardo el resultado que quiero mostrar en variables
+
$a = rand(1, 100); //Genero un número aleatorio
+
$fecha = date("d m Y", time()); //Obtenemos la fecha
+
$title = "Hoy, $fecha, veremos si '$a' es par o impar "; //Creo un título
+
if ($a % 2 == 0) //Si el número es par
+
    $msj = "El número $a es par";
+
else
+
    $msj = "El número $a es impar";
+
?>
+
  
<!-- Ahora metemos el código php cuando lo necesitemos-->
+
{{MRM_Actividad|Title=Ejercicio 1 : [[Usuario/ProgramacionWeb/Sintaxis/ejercicios/ejercicio1|Usando echo]]|
<!------------------- VISTA (solo la parte php)----------------------->
+
<!DOCTYPE html>
+
<html>
+
    <head>
+
        <meta charset="UTF-8">
+
        <title>probando php</title>
+
    </head>
+
    <body>
+
        <h1> <?php echo $title ?></h1>
+
        <hr  />
+
        <h3> <?php echo $msj ?></h3>
+
  
    </body>
+
*Realiza un programa donde visualices un mensaje usando '''la instrucción echo'''.
</html>
+
*Prueba a insertar caracteres especiales como '''\n, \t'''.
 +
¿Qué diferencia hay en usar \n e insertar la etiqueta
 +
<source lang="html5">
 +
<br/>
 
</source>
 
</source>
 
+
?
 
+
*Prueba ambas y verifica la salida visualizando el código fuente del recurso generado.
 
}}
 
}}
 +
=== print ===
  
 +
Es similar a echo en funcionalidad, pero con dos diferencias importantes:
 +
*Solo acepta un argumento.
 +
*Devuelve un valor booleano que indica si la impresión ha sido exitosa (true si lo ha sido).
  
 +
<source lang="php">
 +
<?php
 +
  print "Un solo argumento";
 +
  $success = print "Texto impreso";
 +
?>
 +
</source>
 +
;Ejemplo de diferencia entre echo y print
  
 +
<source lang="php">
 +
<?php
 +
echo "Hola", " Mundo"; // Correcto: echo admite múltiples argumentos.
 +
print "Hola Mundo"; // Correcto: print solo acepta un argumento.
 +
?>
 +
</source>
 +
{{MRM_Actividad|Title=Ejercicio 2 : [[Usuario/ProgramacionWeb/Sintaxis/ejercicios/ejercicio2|Usando echo y print]]|
  
 +
*Realiza un programa que imprima un mensaje con '''echo''' y otro con '''print'''.
 +
*Prueba a pasar múltiples argumentos con echo y compara con print, que solo permite un argumento.
 +
}}
 +
=== printf ===
  
 +
*'''printf''' permite imprimir texto formateado.
 +
Es similar a su uso en otros lenguajes como C o Java.
 +
Los especificadores de formato permiten definir cómo se visualizan los valores.
  
</div>
+
{| class="wikitable"
 +
! Especificador !! Descripción
 +
|-
 +
| '''%s''' || String (cadena de texto)
 +
|-
 +
| '''%c''' || Carácter
 +
|-
 +
| '''%d''' || Decimal con signo
 +
|-
 +
| '''%u''' || Decimal sin signo
 +
|-
 +
| '''%o''' || Octal
 +
|-
 +
| '''%x / %X''' || Hexadecimal
 +
|-
 +
| '''%b''' || Binario
 +
|-
 +
| '''%f / %F''' || Float con decimales
 +
|-
 +
| '''%e / %E''' || Notación científica
 +
|}
  
<div class="slide">
+
Ejemplo:
  
===Escribir PHP con directivas de inclusión===
+
<source lang="php">
*Podemos escribir el código php escribiéndolo en un fichero  aparte y luego lo incluimos.
+
<?php
**Incluimos el fichero explícitamente
+
$n = 5.25251;  
**Para ello usamos directivas o instrucciones del tipo '''''include'''''
+
printf("El valor con 2 decimales es %.2f", $n);
<source lang=php>
+
// La línea de arriba, mostrará 5.25, solo dos decimales.
  include('ruta/nobrefichero');
+
?>
  require('ruta/nobrefichero');
+
</source>
  include_once('ruta/nombrefichero');
+
{{MRM_Actividad|Title=Ejercicio 3 : [[Usuario/ProgramacionWeb/Sintaxis/ejercicios/ejercicio3|Probando printf]]|
  require_once('ruta/nombrefichero');
+
</source>
+
</div>
+
  
<div class="slide">
+
*Asigna un valor real a una variable.
;Ambas son palabras reservadas del lenguaje y sirven para incluir el contenido de un fichero con sentencias php en esa posición del código.
+
*Visualiza ese valor con distintos formatos: %s, %f, %F, %c, %x, %X, %b, %o.
{{MRM_Puntos clave|Title=Include Vs Require|
+
*Prueba a especificar el número de decimales con %f. }}
*Ambas incluyen el contenido de un fichero php en esa posición
+
<br />
**Con include si no se encuentra se continúa ejecutando en esa posición
+
=== print_r ===
**Con require si no está el fichero se detiene en ese punto la ejecución del script}}
+
</div>
+
  
<div class="slide">
+
*La función '''print_r''' se utiliza para imprimir el valor de arrays o de objetos de manera legible.
{{MRM_Puntos clave|Title=include/require Vs include_once/require_once |
+
*Imprime una representación de datos de estructuras complejas (como arrays y objetos).
*Ambas incluyen el contenido de un fichero php en esa posición
+
*Por defecto, devuelve '''true''' si la salida se imprime directamente.
**include/require siempre buscan e incluyen el fichero en esa posición
+
*Si se utiliza el segundo parámetro '''return''' como '''true''', en lugar de imprimir el valor, devolverá el resultado como un string.
**include_once/require_once antes de incluirlo mira a ver si ya lo incluyó previamente en cuyo caso ya no lo hace}}
+
*Es útil para depuración rápida.
</div>
+
Ejemplo:
  
<div class="slide">
+
<source lang="php">
{{MRM_Actividad|Title=Probando include require
+
<?php $array = array("manzana", "plátano", "naranja");
|Crea 4 ficheros con el siguiente código
+
print_r($array);  
'''''fichero_include.php'''''
+
<source lang=php>
+
<?php
+
  echo "<b><i>Hola desde un fichero include </b></i><hr />";
+
 
?>
 
?>
</source>
+
  </source>
'''''fichero_include_once.php'''''
+
; Salida:
<source lang=php>
+
<?php
+
  echo "<b><i>Hola desde un fichero include once </b></i><hr />";
+
?>
+
</source>
+
'''''fichero_require.php'''''
+
<source lang=php>
+
<?php
+
  echo "<b><i>Hola desde un fichero require </b></i><hr />";
+
?>
+
</source>
+
'''''fichero_require_once.php'''''
+
<source lang=php>
+
<?php
+
  echo "<b><i>Hola desde un fichero require once </b></i><hr />";
+
?>
+
</source>
+
'''''Ahora crea un programa principal dónde uses las instrucciones de inclusión vistas en este apartado'''''.
+
<source lang=php>
+
<?php
+
  
echo "<h2>Ahora vamos a incluir un fichero con include</h2>";
+
<pre> Array ( [0] => manzana [1] => plátano [2] => naranja ) </pre>
include 'ficheros/fichero_include.php';
+
*Si deseas que el resultado sea devuelto en una cadena en lugar de ser impreso, puedes pasar el segundo parámetro true.
 +
<source lang="php">
 +
<?php
 +
  $array = array("manzana", "plátano", "naranja");  
 +
  $resultado = print_r($array, true); // Guardar en una variable en lugar de imprimir. ?> </source>
  
echo "<h2>ahora vamos a incluir un fichero con require</h2>";
+
=== var_dump ===
require 'ficheros/fichero_require.php';
+
  
echo "<h2>Ahora vamos a incluir un fichero con include_once</h2>";
+
*var_dump es una función más detallada que imprime '''el tipo y valor de cualquier expresión''' (variables, arrays, objetos, etc.).
include_once 'ficheros/fichero_include_once.php';
+
*Además de mostrar el valor, también muestra el tipo de datos y la longitud del valor (en el caso de arrays o strings).
 +
*Es la función de depuración más completa para inspeccionar variables.
 +
<source lang="php">
 +
<?php
 +
$cadena = "Hola Mundo";  
 +
$numero = 42;
 +
$flotante = 3.1416;
 +
$array = array(1, 2, 3);
 +
var_dump($cadena);
 +
var_dump($numero);
 +
var_dump($flotante);
 +
var_dump($array);
 +
?> </source>
 +
; Salida:
  
echo "<h2>Ahora vamos a incluir un fichero con require_once</h2>";
+
<pre>  
require_once 'ficheros/fichero_require_once.php';
+
  string(10) "Hola Mundo"
 +
  int(42)
 +
  float(3.1416)
 +
    array(3) { [0]=> int(1) [1]=> int(2) [2]=> int(3) } </pre>
 +
{{MRM_Actividad|Title=Ejercicio 4 : [[Usuario/ProgramacionWeb/Sintaxis/ejercicios/ejercicio4|Probando print_r y var_dump]]|
  
echo "<h2>Ahora vamos a incluir un fichero que no existe  con include</h2>";
+
Crea un array con varios elementos y visualízalo utilizando print_r y var_dump.
include 'ficheros/fichero_no_existe_include.php';
+
Prueba a pasar diferentes tipos de datos a var_dump y observa cómo muestra el tipo y valor de cada uno.
echo "Vemos que no pasa nada, por que el fichero no existe pero sigue <hr />";
+
}}
  
echo "<h2>Ahora volvemos  a incluir un fichero con include_once</h2>";
+
<br />
include_once 'ficheros/fichero_include_once.php';
+
{{MRM_Resumen|title=Conclusiones|
echo "Vemos que no pasa nada, por que el fichero ya se había incluido y no se vuelve a incluir<hr />";
+
*'''echo''' es la función más simple para imprimir texto y puede aceptar múltiples argumentos.
 +
*'''print''' es similar a echo, pero solo acepta un argumento y devuelve un valor booleano.
 +
*'''printf''' permite imprimir con formato, ideal para cuando se necesita control sobre el formato de salida.
 +
*'''print_r''' es útil para imprimir arrays y objetos en un formato legible.
 +
*'''var_dump''' proporciona una salida detallada del tipo y valor de cualquier variable, útil para depuración más avanzada.
 +
}}
  
echo "<h2>Ahora volvemos  a incluir un fichero con require_once</h2>";
+
<!--
require_once 'ficheros/fichero_require_once.php';
+
{{MRM_Actividad|Title=Ejercicio 3 : [[Usuario:ManuelRomero/ProgramacionWeb/Sintaxis/ejercicios/ejercicio3|printf, tabla ascii ]]|
echo "Vemos que no pasa nada, por que el fichero ya se había incluido y no se vuelve a incluir<hr />";
+
*Usando la estructura de control '''''for'''''
 
+
<source lang=php>
echo "<h2>Ahora vamos a incluir un fichero con include para ver que sí que se vuelve a incluir</h2>";
+
for ($n=32; $n<128: $n++){ //iterará $n desde 32 hasta el valor 128
include 'ficheros/fichero_include.php';
+
}
 
+
echo "<h2>Ahora vamos a incluir un fichero con require y vemos que sí se vuelve a incluir</h2>";
+
require 'ficheros/fichero_require.php';
+
 
+
echo "<h2>Ahora no incluimos con require un fichero que no existe</h2>";
+
require 'ficheros/fichero_no_existe_require.php';
+
echo "Esta línea ya no se imprimirá ni nada que vaya después de aquí";
+
?>
+
 
</source>
 
</source>
</div>
+
*Para mostrar una tabla básica, las etiquetas  '''''html''''' serán
<div class="slide">
+
<source lang=html5>
{{Tip|
+
<table>
*Siéntete cómoda en modificar el fichero y ver el resultado
+
    <caption></caption>
*Observa que estas instrucciones no son exactamente funciones, por lo que no necesitan paréntesis (aunque se puede poner por mantener una homogeneidad con sintaxis del uso o invocación de funciones)
+
    <tr>
<source lang=php>
+
        <th>titulo 1</th>
include 'ficheros/fichero_include.php'
+
        <th>titulo 2</th>
//Es léxicamente y sintácticamente igual que
+
    <tr>
include ('ficheros/fichero_include.php');
+
        <td></td>
 +
    ......
  
 +
</table>
 
</source>
 
</source>
 +
*Realiza el programa que genere dicha información
 
}}
 
}}
}}
+
-->
 
</div>
 
</div>
 
 
 
 
<div class="slide">
 
<div class="slide">
{{MRM_Recursos de la Web|
 
*[http://php.net/manual/es/ php] página oficial en español LO MEJOR!!!!
 
*http://php.net/manual/es/
 
*<!-- MRM incluir en el otro documento http://php.net/manual/es/ini.core.php -->
 
 
}}
 
</div>
 
 
<div class=slide>
 

Última revisión de 17:30 21 oct 2024

string

  • Antes de ver cómo escribir un string (echo), vamos a comentar los string.
  • Un string es una cadena de caracteres.
  • Para representarla encerraremos caracteres entre comillas simples o commillas dobles, que dependiendo de lo que contenga, puede tener diferentes comportameninto, como veremos posteriormente.
"Esto es una cadena encerrada entre comillas dobles que tiene caracteres, 
números 12345 y algún caracter no letra como % & y = y cualquiera en principio será imprimible"
'Esto es una cadena encerrada entre comillas dobles que tiene caracteres,
números 12345 y algún caracter no letra como % & y = y cualquiera en principio será imprimible'
  • Dentro de un string, además de caracteres imprimibles como en el ejemplo anterior, pero también hay caracteres que tienen un significado especial, y ahí será diferente usar comillas simples y comillas dobles.
Caracteres especiales

Los siguientes caracteres son especiales, esto implica que no se imprimirán y tendrán algún tipo de efecto con los caracteres que le siguen:

Carácter Significado Ejemplo Acción
$ Sintaxis simple de interpretacion de variable $edad Se sustituirá la variable por su valor en este caso por el valor de $edad
\ Secuenca de escape El carácter que le sigue será interpretado como una secuencia de escape (ver tabla posterior)
{} Sintaxis compleja ${nota['maria']} Se realiza una doble interpretación en este caso para acceder a un elemento de un array
secuencia de escape
Caracteres especiales con \
https://www.php.net/manual/es/regexp.reference.escape.php
  • Secuencias de escape: hay caracteres no imprimibles que podemos querer representar, para ello usaremos la barra invertida \.
Secuencia de escape Significado
\’ Comillas simples
\" Comillas dobles
\\ Barra invertida
\n Nueva linea (endl)
\r Retorno
\t Tabulación Horizontal
\v Tabulación Vertical
\0 - \777 Código ascii(octal)
\x0 - \xFF Código ascii (hexadecimal)
  • Para especificar una cadena de caracteres posemos usar "", (más adelante veremos otras dos formas muy parecidas que son con el operador <<<, conocidos como heredoc y newdoc)
  • Aquí hay una gran diferencia en usar las comillas dobles "", y utilizar las comillas simples


Icon key points.gif

Comillas dobles

Interpretan los caracteres especiales
  • $ Especifico una variable por sintaxis simple
  • \ [#secuencia de escape



Icon key points.gif

Comillas simples

No interpreta los caracteres especiales, salvo
  • \'
  • \\



Funciones de salida

  • Construcciones básicas para salida de caracteres
  • En PHP,en realidad no son funciones por lo que pueden ir sin paréntesis (con o sin paréntesis):
echo
print
  • Existen otras funciones que iremos viendo según avance el curso, pero podemos probar ahora
printf
print_r
var_dump
  • Antes de continuar viendo echo, vamos a presentar los valores cadena de caracteres o string

echo

  • Es la función más sencilla para imprimir texto en PHP.
  • Imprime una cadena como argumento.
  • En la versión sin paréntesis, también puedes pasar una lista de argumentos.
 <?php echo "primer argumento", "segundo argumento", "tercer argumento"; ?>
Secuencias de escape
  • Cuando escribimos texto con echo, este texto se envía al navegador o recurso que solicitó la página. El navegador se encarga de interpretar y renderizar el HTML generado.
  • Puedes usar secuencias de escape como \n para un salto de línea en la salida HTML, aunque esta no será visible directamente en el navegador, sino solo en el código fuente del HTML.
Etiquetas HTML
  • Si se incluyen etiquetas HTML con echo, estas se enviarán tal cual al navegador, que las renderizará correctamente.



Icon activity.jpg
Ejercicio 1 : Usando echo
  • Realiza un programa donde visualices un mensaje usando la instrucción echo.
  • Prueba a insertar caracteres especiales como \n, \t.

¿Qué diferencia hay en usar \n e insertar la etiqueta

<br/>

?

  • Prueba ambas y verifica la salida visualizando el código fuente del recurso generado.



print

Es similar a echo en funcionalidad, pero con dos diferencias importantes:

  • Solo acepta un argumento.
  • Devuelve un valor booleano que indica si la impresión ha sido exitosa (true si lo ha sido).
 <?php
  print "Un solo argumento";
  $success = print "Texto impreso"; 
 ?>
Ejemplo de diferencia entre echo y print
 
<?php 
 echo "Hola", " Mundo"; // Correcto: echo admite múltiples argumentos.
 print "Hola Mundo"; // Correcto: print solo acepta un argumento. 
?>


Icon activity.jpg
Ejercicio 2 : Usando echo y print
  • Realiza un programa que imprima un mensaje con echo y otro con print.
  • Prueba a pasar múltiples argumentos con echo y compara con print, que solo permite un argumento.



printf

  • printf permite imprimir texto formateado.
Es similar a su uso en otros lenguajes como C o Java.
Los especificadores de formato permiten definir cómo se visualizan los valores.
Especificador Descripción
%s String (cadena de texto)
%c Carácter
%d Decimal con signo
%u Decimal sin signo
%o Octal
%x / %X Hexadecimal
%b Binario
%f / %F Float con decimales
%e / %E Notación científica

Ejemplo:

 <?php
 $n = 5.25251; 
 printf("El valor con 2 decimales es %.2f", $n);
 // La línea de arriba, mostrará 5.25, solo dos decimales.
 ?>


Icon activity.jpg
Ejercicio 3 : Probando printf
  • Asigna un valor real a una variable.
  • Visualiza ese valor con distintos formatos: %s, %f, %F, %c, %x, %X, %b, %o.
  • Prueba a especificar el número de decimales con %f.



print_r

  • La función print_r se utiliza para imprimir el valor de arrays o de objetos de manera legible.
  • Imprime una representación de datos de estructuras complejas (como arrays y objetos).
  • Por defecto, devuelve true si la salida se imprime directamente.
  • Si se utiliza el segundo parámetro return como true, en lugar de imprimir el valor, devolverá el resultado como un string.
  • Es útil para depuración rápida.

Ejemplo:

 <?php $array = array("manzana", "plátano", "naranja"); 
 print_r($array); 
?>
Salida
 Array ( [0] => manzana [1] => plátano [2] => naranja ) 
  • Si deseas que el resultado sea devuelto en una cadena en lugar de ser impreso, puedes pasar el segundo parámetro true.
 <?php
  $array = array("manzana", "plátano", "naranja"); 
  $resultado = print_r($array, true); // Guardar en una variable en lugar de imprimir. ?>

var_dump

  • var_dump es una función más detallada que imprime el tipo y valor de cualquier expresión (variables, arrays, objetos, etc.).
  • Además de mostrar el valor, también muestra el tipo de datos y la longitud del valor (en el caso de arrays o strings).
  • Es la función de depuración más completa para inspeccionar variables.
 <?php 
 $cadena = "Hola Mundo"; 
 $numero = 42;
 $flotante = 3.1416; 
 $array = array(1, 2, 3); 
 var_dump($cadena); 
 var_dump($numero);
 var_dump($flotante); 
 var_dump($array); 
?>
Salida
 
   string(10) "Hola Mundo" 
   int(42)
   float(3.1416)
    array(3) { [0]=> int(1) [1]=> int(2) [2]=> int(3) } 


Icon activity.jpg

Crea un array con varios elementos y visualízalo utilizando print_r y var_dump. Prueba a pasar diferentes tipos de datos a var_dump y observa cómo muestra el tipo y valor de cada uno.






Icon summary.gif
Resumen
  • echo es la función más simple para imprimir texto y puede aceptar múltiples argumentos.
  • print es similar a echo, pero solo acepta un argumento y devuelve un valor booleano.
  • printf permite imprimir con formato, ideal para cuando se necesita control sobre el formato de salida.
  • print_r es útil para imprimir arrays y objetos en un formato legible.
  • var_dump proporciona una salida detallada del tipo y valor de cualquier variable, útil para depuración más avanzada.