Tipos de Datos Primitivos Simples
Tipos de datos primitivos simples
- Números (numbers): Secuencia de dígitos (pueden incluir el - para negativos y el . para decimales) que representan números.
Ejemplo. 0, -1, 3.1415. - Cadenas (strings): Secuencia de caracteres alfanuméricos que representan texto. Se escriben entre comillas simples o dobles.
Ejemplo. 'Hola', "Adiós". - Booleanos (boolean): Contiene únicamente dos elementos
True
yFalse
que representan los valores lógicos verdadero y falso respectivamente.
Estos datos son inmutables, es decir, su valor es constante y no puede cambiar.
Tipos de datos primitivos compuestos (contenedores)
- Listas (lists): Colecciones de objetos que representan secuencias ordenadas de objetos de distintos tipos. Se representan con corchetes y los elementos se separan por comas.
Ejemplo. [1, "dos", [3, 4], True]. - Tuplas (tuples). Colecciones de objetos que representan secuencias ordenadas de objetos de distintos tipos. A diferencia de las listas son inmutables, es decir, que no cambian durante la ejecución. Se representan mediante paréntesis y los elementos se separan por comas.
Ejemplo. (1, 'dos', 3) - Diccionarios (dictionaries): Colecciones de objetos con una clave asociada. Se representan con llaves, los pares separados por comas y cada par contiene una clave y un objeto asociado separados por dos puntos.
Ejemplo. {'pi':3.1416, 'e':2.718}.
Clase de un dato (type()
)
La clase a la que pertenece un dato se obtiene con el comando type()
Números (clases int
y float
)
Secuencia de dígitos (pueden incluir el - para negativos y el . para decimales) que representan números.
Pueden ser enteros (int
) o reales (float
).
Operadores aritméticos
- Operadores aritméticos:
+
(suma),-
(resta),*
(producto),/
(cociente),//
(cociente división entera),%
(resto división entera),**
(potencia).
Orden de prioridad de evaluación:
Orden | Operador |
---|---|
1 | Funciones predefinidas |
2 | Potencias |
3 | Productos y cocientes |
4 | Sumas y restas |
Se puede saltar el orden de evaluación utilizando paréntesis ( )
.
Operadores lógicos con números
Devuelven un valor lógico o booleano.
- Operadores lógicos:
==
(igual que),>
(mayor que),<
(menor que),>=
(mayor o igual que),<=
(menor o igual que),!=
(distinto de).
Cadenas (clase str
)
Secuencia de caracteres alfanuméricos que representan texto. Se escriben entre comillas sencillas ' o dobles ".
Acceso a los elementos de una cadena
Cada carácter tiene asociado un índice que permite acceder a él.
Cadena | P |
y |
t |
h |
o |
n |
---|---|---|---|---|---|---|
Índice positivo | 0 | 1 | 2 | 3 | 4 | 5 |
Índice negativo | -6 | -5 | -4 | -3 | -2 | -1 |
c[i]
devuelve el carácter de la cadenac
con el índicei
.
El índice del primer carácter de la cadena es 0.
También se pueden utilizar índices negativos para recorrer la cadena del final al principio.
El índice del último carácter de la cadena es -1.
output
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
IndexError: string index out of range
Subcadenas
c[i:j:k]
: Devuelve la subcadena dec
desde el carácter con el índicei
hasta el carácter anterior al índicej
, tomando caracteres cadak
.
Operaciones con cadenas
c1 + c2
: Devuelve la cadena resultado de concatenar las cadenasc1
yc2
.c * n
: Devuelve la cadena resultado de concatenarn
copias de la cadenac
.c1 in c2
: DevuelveTrue
sic1
es una cadena concenida enc2
yFalse
en caso contrario.c1 not in c2
: DevuelveTrue
sic1
es una cadena no concenida enc2
yFalse
en caso contrario.
Operaciones de comparación de cadenas
c1 == c2
: DevuelveTrue
si la cadenac1
es igual que la cadenac2
yFalse
en caso contrario.c1 > c2
: DevuelveTrue
si la cadenac1
sucede a la cadenac2
yFalse
en caso contrario.c1 < c2
: DevuelveTrue
si la cadenac1
antecede a la cadenac2
yFalse
en caso contrario.c1 >= c2
: DevuelveTrue
si la cadenac1
sucede o es igual a la cadenac2
yFalse
en caso contrario.c1 <= c2
: DevuelveTrue
si la cadenac1
antecede o es igual a la cadenac2
yFalse
en caso contrario.c1 != c2
: DevuelveTrue
si la cadenac1
es distinta de la cadenac2
yFalse
en caso contrario.
Utilizan el orden establecido en el código ASCII.
Funciones de cadenas
len(c)
: Devuelve el número de caracteres de la cadenac
.min(c)
: Devuelve el carácter menor de la cadenac
.max(c)
: Devuelve el carácter mayor de la cadenac
.c.upper()
: Devuelve la cadena con los mismos caracteres que la cadenac
pero en mayúsculas.c.lower()
: Devuelve la cadena con los mismos caracteres que la cadenac
pero en minúsculas.c.title()
: Devuelve la cadena con los mismos caracteres que la cadenac
con el primer carácter en mayúsculas y el resto en minúsculas.c.split(delimitador)
: Devuelve la lista formada por las subcadenas que resultan de partir la cadenac
usando como delimitador la cadenadelimitador
. Si no se especifica el delimitador utiliza por defecto el espacio en blanco.
Cadenas formateadas (format()
)
c.format(valores)
: Devuelve la cadenac
tras sustituir los valores de la secuenciavalores
en los marcadores de posición dec
. Los marcadores de posición se indican mediante llaves{}
en la cadenac
, y el reemplazo de los valores se puede realizar por posición, indicando en número de orden del valor dentro de las llaves, o por nombre, indicando el nombre del valor, siempre y cuando los valores se pasen con el formatonombre = valor
.
Los marcadores de posición, a parte de indicar la posición de los valores de reemplazo, pueden indicar también el formato de estos. Para ello se utiliza la siguiente sintaxis:
{:n}
: Alinea el valor a la izquierda rellenando con espacios por la derecha hasta losn
caracteres.{:>n}
: Alinea el valor a la derecha rellenando con espacios por la izquierda hasta losn
caracteres.{:^n}
: Alinea el valor en el centro rellenando con espacios por la izquierda y por la derecha hasta losn
caracteres.{:nd}
: Formatea el valor como un número entero conn
caracteres rellenando con espacios blancos por la izquierda.{:n.mf}
: Formatea el valor como un número real con un tamaño den
caracteres (incluído el separador de decimales) ym
cifras decimales, rellenando con espacios blancos por la izquierda.
Datos lógicos o booleanos (clase bool
)
Contiene únicamente dos elementos True
y False
que representan los valores lógicos verdadero y falso respectivamente.
False
tiene asociado el valor 0 y True
tiene asociado el valor 1.
Operaciones con valores lógicos
- Operadores lógicos:
==
(igual que),>
(mayor),<
(menor),>=
(mayor o igual que),<=
(menor o igual que),!=
(distinto de). not b
(negación) : DevuelveTrue
si el dato booleanob
esFalse
, yFalse
en caso contrario.b1 and b2
: DevuelveTrue
si los datos booleanosb1
yb2
sonTrue
, yFalse
en caso contrario.b1 or b2
: DevuelveTrue
si alguno de los datos booleanosb1
ob2
sonTrue
, yFalse
en caso contrario.
Tabla de verdad
x |
y |
not x |
x and y |
x or y |
---|---|---|---|---|
False |
False |
True |
False |
False |
False |
True |
True |
False |
True |
True |
False |
False |
False |
True |
True |
True |
False |
True |
True |
Conversión de datos primitivos simples
Las siguientes funciones convierten un dato de un tipo en otro, siempre y cuando la conversión sea posible.
int()
convierte a entero.
Ejemplo.int('12')
12
int(True)
1
int('c')
Errorfloat()
convierte a real.
Ejemplo.float('3.14')
3.14
float(True)
1.0
float('III')
Errorstr()
convierte a cadena.
Ejemplo.str(3.14)
'3.14'
str(True)
'True'
bool()
convierte a lógico.
Ejemplo.bool('0')
False
bool('3.14')
True
bool('')
False
bool('Hola')
True
Variables
Una variable es un identificador ligado a algún valor.
Reglas para nombrarlas:
- Comienzan siempre por una letra, seguida de otras letras o números.
- No se pueden utilizarse palabras reservadas del lenguaje.
A diferencia de otros lenguajes no tienen asociado un tipo y no es necesario declararlas antes de usarlas (tipado dinámico).
Para asignar un valor a una variable se utiliza el operador =
y para borrar una variable se utiliza la instrucción del
.