learnxinyminutes-docs/es-es/hy-es.html.markdown

170 lines
6.2 KiB
Markdown
Raw Normal View History

2019-10-01 19:35:49 +00:00
---
2024-10-20 21:46:35 +00:00
language: Hy
2019-10-01 19:49:37 +00:00
filename: learnhy-es.hy
2019-10-01 19:35:49 +00:00
contributors:
2019-10-01 19:49:37 +00:00
- ["Abhishek L", "http://twitter.com/abhishekl"]
2019-10-01 19:35:49 +00:00
translators:
2019-10-01 19:49:37 +00:00
- ["Roberto R", "https://github.com/rrodriguze"]
lang: es-es
2019-10-01 19:35:49 +00:00
---
Hy es un lenguaje de Lisp escrito sobre Python. Esto es posible convirtiendo
código Hy en un árbol abstracto de Python (ast). Por lo que, esto permite a
2024-04-25 18:27:55 +00:00
Hy llamar a código Python nativo y viceversa.
2019-10-01 19:35:49 +00:00
2024-04-25 18:27:55 +00:00
```hylang
2019-10-01 19:35:49 +00:00
;; Esto es una intrucción muy básica a Hy, como la del siguiente enlace
2024-04-25 18:27:55 +00:00
;; https://hylang.org/try-hy
2019-10-01 19:35:49 +00:00
;;
2024-04-25 18:27:55 +00:00
; Comentarios usando punto y coma, como en otros Lisps
2019-10-01 19:35:49 +00:00
;; Nociones básicas de expresiones
; Los programas List están hechos de expresiones simbólicas como la siguiente
(some-function args)
; ahora el esencial "Hola Mundo"
(print "hello world")
;; Tipos de datos simples
; Todos los tipos de datos simples son exactamente semejantes a sus homólogos
2024-04-25 18:27:55 +00:00
; en Python
2019-10-01 19:35:49 +00:00
42 ; => 42
3.14 ; => 3.14
True ; => True
4+10j ; => (4+10j) un número complejo
; Vamos a comenzar con un poco de arimética simple
(+ 4 1) ;=> 5
2024-04-25 18:27:55 +00:00
; el operador es aplicado a todos los argumentos, como en otros Lisps
2019-10-01 19:35:49 +00:00
(+ 4 1 2 3) ;=> 10
(- 2 1) ;=> 1
(* 4 2) ;=> 8
(/ 4 1) ;=> 4
(% 4 2) ;=> 0 o operador módulo
2024-04-25 18:27:55 +00:00
; la exponenciación es representada por el operador ** como Python
2019-10-01 19:35:49 +00:00
(** 3 2) ;=> 9
; las funciones anidadas funcionan como lo esperado
(+ 2 (* 4 2)) ;=> 10
; también los operadores lógicos igual o no igual se comportan como se espera
(= 5 4) ;=> False
(not (= 5 4)) ;=> True
;; variables
; las variables se configuran usando SETV, los nombres de las variables pueden
; usar utf-8, excepto for ()[]{}",'`;#|
(setv a 42)
(setv π 3.14159)
(def *foo* 42)
;; otros tipos de datos de almacenamiento
; strings, lists, tuples & dicts
2024-04-25 18:27:55 +00:00
; estos son exactamente los mismos tipos de almacenamiento en Python
2019-10-01 19:35:49 +00:00
"hello world" ;=> "hello world"
2024-04-25 18:27:55 +00:00
; las operaciones de cadena funcionan de manera similar en Python
2019-10-01 19:35:49 +00:00
(+ "hello " "world") ;=> "hello world"
; Las listas se crean usando [], la indexación comienza en 0
(setv mylist [1 2 3 4])
; las tuplas son estructuras de datos inmutables
(setv mytuple (, 1 2))
; los diccionarios son pares de valor-clave
(setv dict1 {"key1" 42 "key2" 21})
; :nombre se puede usar para definir palabras clave en Hy que se pueden usar para claves
(setv dict2 {:key1 41 :key2 20})
; usar 'get' para obtener un elemento en un índice/key
(get mylist 1) ;=> 2
(get dict1 "key1") ;=> 42
; Alternativamente, si se usan palabras clave que podrían llamarse directamente
(:key1 dict2) ;=> 41
;; funciones y otras estructuras de programa
; las funciones son definidas usando defn, o el último sexp se devuelve por defecto
(defn greet [name]
  "A simple greeting" ; un docstring opcional
  (print "hello " name))
(greet "bilbo") ;=> "hello bilbo"
; las funciones pueden tener argumentos opcionales, así como argumentos-clave
(defn foolists [arg1 &optional [arg2 2]]
  [arg1 arg2])
(foolists 3) ;=> [3 2]
(foolists 10 3) ;=> [10 3]
; las funciones anonimas son creadas usando constructores 'fn' y 'lambda'
; que son similares a 'defn'
(map (fn [x] (* x x)) [1 2 3 4]) ;=> [1 4 9 16]
;; operaciones de secuencia
2024-04-25 18:27:55 +00:00
; Hy tiene algunas utilidades incluidas para operaciones de secuencia, etc.
2019-10-01 19:35:49 +00:00
; recuperar el primer elemento usando 'first' o 'car'
(setv mylist [1 2 3 4])
(setv mydict {"a" 1 "b" 2})
(first mylist) ;=> 1
2024-04-25 18:27:55 +00:00
; corte listas usando 'cut'
(cut mylist 1 3) ;=> [2 3]
2019-10-01 19:35:49 +00:00
; obtener elementos de una lista o dict usando 'get'
(get mylist 1) ;=> 2
(get mydict "b") ;=> 2
2024-04-25 18:27:55 +00:00
; la lista de indexación comienza a partir de 0, igual que en Python
2019-10-01 19:35:49 +00:00
; assoc puede definir elementos clave/índice
(assoc mylist 2 10) ; crear mylist [1 2 10 4]
(assoc mydict "c" 3) ; crear mydict {"a" 1 "b" 2 "c" 3}
2024-04-25 18:27:55 +00:00
; hay muchas otras funciones que hacen que trabajar con secuencias sea
2019-10-01 19:35:49 +00:00
; entretenido
;; Python interop
2024-04-25 18:27:55 +00:00
;; los import funcionan exactamente como en Python
2019-10-01 19:35:49 +00:00
(import datetime)
2024-04-25 18:27:55 +00:00
(import functools [partial reduce]) ; importa fun1 e fun2 del module1
(import matplotlib.pyplot :as plt) ; haciendo una importación en foo como en bar
; todos los métodos de Python incluídos etc. son accesibles desde Hy
2019-10-01 19:35:49 +00:00
; a.foo(arg) is called as (.foo a arg)
(.split (.strip "hello world  ")) ;=> ["hello" "world"]
;; Condicionales
; (if condition (body-if-true) (body-if-false)
(if (= passcode "moria")
  (print "welcome")
  (print "Speak friend, and Enter!"))
; anidar múltiples cláusulas 'if else if' con condiciones
(cond
2024-04-25 18:27:55 +00:00
 (= someval 42) (print "Life, universe and everything else!")
 (> someval 42) (print "val too large")
 (< someval 42) (print "val too small"))
2019-10-01 19:35:49 +00:00
; declaraciones de grupo con 'do', son ejecutadas secuencialmente
; formas como defn tienen un 'do' implícito
(do
 (setv someval 10)
 (print "someval is set to " someval)) ;=> 10
; crear enlaces léxicos con 'let', todas las variables definidas de esta manera
; tienen alcance local
(let [[nemesis {"superman" "lex luther"
                "sherlock" "moriarty"
                "seinfeld" "newman"}]]
  (for [(, h v) (.items nemesis)]
    (print (.format "{0}'s nemesis was {1}" h v))))
;; clases
; las clases son definidas de la siguiente manera
2024-04-25 18:27:55 +00:00
(defclass Wizard [object]
  (defn __init__ [self spell]
    (setv self.spell spell))
  (defn get-spell [self]
    self.spell))
2019-10-01 19:35:49 +00:00
```
### Otras lecturas
2024-04-25 18:27:55 +00:00
Este tutorial apenas es una introducción básica para Hy/Lisp/Python.
2019-10-01 19:35:49 +00:00
2024-04-25 18:27:55 +00:00
Docs Hy: [https://hylang.org/hy/doc](https://hylang.org/hy/doc)
2019-10-01 19:35:49 +00:00
2024-04-25 18:27:55 +00:00
Repo Hy en GitHub: [https://github.com/hylang/hy](https://github.com/hylang/hy)
2019-10-01 19:35:49 +00:00
Acceso a freenode irc con #hy, hashtag en twitter: #hylang