2013-08-14 19:12:21 +02:00
|
|
|
---
|
|
|
|
language: ruby
|
|
|
|
filename: learnruby-fr.rb
|
|
|
|
contributors:
|
|
|
|
- ["David Underwood", "http://theflyingdeveloper.com"]
|
|
|
|
- ["Joel Walden", "http://joelwalden.net"]
|
|
|
|
- ["Luke Holder", "http://twitter.com/lukeholder"]
|
|
|
|
- ["Tristan Hume", "http://thume.ca/"]
|
|
|
|
- ["Nick LaMuro", "https://github.com/NickLaMuro"]
|
2017-07-11 15:37:49 +02:00
|
|
|
|
2013-08-14 19:12:21 +02:00
|
|
|
translators:
|
|
|
|
- ["Geoffrey Roguelon", "https://github.com/GRoguelon"]
|
2013-08-15 10:45:06 +02:00
|
|
|
- ["Nami-Doc", "https://github.com/Nami-Doc"]
|
2017-07-11 15:37:49 +02:00
|
|
|
- ["Sylvain Abélard", "http://github.com/abelards"]
|
2013-08-14 19:12:21 +02:00
|
|
|
lang: fr-fr
|
|
|
|
---
|
|
|
|
|
|
|
|
```ruby
|
|
|
|
# Ceci est un commentaire
|
|
|
|
|
|
|
|
=begin
|
|
|
|
Ceci est un commentaire multiligne
|
|
|
|
Personne ne les utilise
|
|
|
|
Vous devriez en faire de même
|
|
|
|
=end
|
|
|
|
|
2017-07-11 15:37:49 +02:00
|
|
|
# Tout d'abord : tout est un objet.
|
2013-08-14 19:12:21 +02:00
|
|
|
|
|
|
|
# Les nombres sont des objets
|
|
|
|
|
2017-07-11 15:37:49 +02:00
|
|
|
3.class #=> Fixnum # on voit que c'est une classe Ruby et non un "type spécial"
|
2013-08-14 19:12:21 +02:00
|
|
|
|
2017-07-11 15:37:49 +02:00
|
|
|
3.to_s #=> "3" # on peut appeler des méthodes sur ces objets, comme `to_s` (transforme en texte)
|
2013-08-14 19:12:21 +02:00
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Les opérateurs de base
|
2013-08-14 19:12:21 +02:00
|
|
|
1 + 1 #=> 2
|
|
|
|
8 - 1 #=> 7
|
|
|
|
10 * 2 #=> 20
|
2017-07-11 15:37:49 +02:00
|
|
|
22 / 7 #=> 3 # si les deux éléments sont entiers, c'est une division entière
|
|
|
|
22.0 / 7 #=> 3.142857142857143
|
|
|
|
22 / 7.0 #=> 3.142857142857143
|
|
|
|
2**10 #=> 1024 # exposant
|
|
|
|
1024 % 10 #=> 4 # modulo (reste de la division euclidienne)
|
2013-08-14 19:12:21 +02:00
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Les opérateurs sont juste des raccourcis
|
|
|
|
# pour appeler une méthode sur un objet
|
2013-08-14 19:12:21 +02:00
|
|
|
1.+(3) #=> 4
|
|
|
|
10.* 5 #=> 50
|
|
|
|
|
|
|
|
# Les valeurs spéciales sont des objets
|
2017-07-11 15:37:49 +02:00
|
|
|
nil # nul, vide ou indéfini
|
|
|
|
true # vrai
|
|
|
|
false # faux
|
2013-08-14 19:12:21 +02:00
|
|
|
|
|
|
|
nil.class #=> NilClass
|
|
|
|
true.class #=> TrueClass
|
|
|
|
false.class #=> FalseClass
|
|
|
|
|
|
|
|
# Égalité
|
|
|
|
1 == 1 #=> true
|
|
|
|
2 == 1 #=> false
|
|
|
|
|
|
|
|
# Inégalité
|
|
|
|
1 != 1 #=> false
|
|
|
|
2 != 1 #=> true
|
|
|
|
!true #=> false
|
|
|
|
!false #=> true
|
|
|
|
|
2017-07-11 15:37:49 +02:00
|
|
|
# à part false lui-même, nil est la seule autre valeur "considérée comme fausse"
|
2013-08-14 19:12:21 +02:00
|
|
|
!nil #=> true
|
|
|
|
!false #=> true
|
|
|
|
!0 #=> false
|
|
|
|
|
|
|
|
# Plus de comparaisons
|
|
|
|
1 < 10 #=> true
|
|
|
|
1 > 10 #=> false
|
|
|
|
2 <= 2 #=> true
|
|
|
|
2 >= 2 #=> true
|
|
|
|
|
|
|
|
# Les chaînes de caractères sont des objets
|
|
|
|
'Je suis une chaîne de caractères'.class #=> String
|
|
|
|
"Je suis également une chaîne de caractères".class #=> String
|
|
|
|
|
|
|
|
placeholder = "utiliser l'interpolation de chaîne de caractères"
|
|
|
|
"Je peux #{placeholder} quand j'utilise les guillemets"
|
|
|
|
#=> "Je peux utiliser l'interpolation de chaîne de caractères quand j'utilise les guillemets"
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Affichez un message
|
2013-08-14 19:12:21 +02:00
|
|
|
puts "J'affiche à l'écran!"
|
|
|
|
|
2017-07-11 15:37:49 +02:00
|
|
|
# Il y a quelques autres raccourcis pour les chaînes de caractères
|
|
|
|
rb = "Ruby"
|
|
|
|
interpolation = "Bonjour Ruby" # s'écrit aussi %Q[Bonjour #{rb}] %Q{Bonjour #{rb}} avec l'interpolation
|
|
|
|
literal = "Bonjour \#{rb}" # avec le backslash, le dièse est un "vrai dièse" (le slash ne s'affiche que pour le debug)
|
|
|
|
literal == %q[Bonjour #{rb}] # le Q majuscule fait l'interpolation, le q minuscule ne la fait pas
|
|
|
|
multi = %Q[Cette chaîne
|
|
|
|
est sur plusieurs
|
|
|
|
lignes] # => "Cette chaîne\nest sur plusieurs\nlignes" # le caractère \n signifie retour à la ligne
|
|
|
|
|
2013-08-14 19:12:21 +02:00
|
|
|
# Variables
|
|
|
|
x = 25 #=> 25
|
|
|
|
x #=> 25
|
|
|
|
|
|
|
|
# Notez que l'affectation retourne la valeur affectée.
|
|
|
|
# Cela signifie que vous pouvez affecter plusieurs fois de suite :
|
|
|
|
|
|
|
|
x = y = 10 #=> 10
|
|
|
|
x #=> 10
|
|
|
|
y #=> 10
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Par convention, utilisez la notation underscore
|
|
|
|
# pour nommer les variables
|
2013-08-14 19:12:21 +02:00
|
|
|
snake_case = true
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Utilisez des noms de variable explicites
|
2013-08-14 19:12:21 +02:00
|
|
|
path_to_project_root = '/nom/correct/'
|
|
|
|
path = '/mauvais/nom/'
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Symboles (aussi des objets)
|
2013-08-14 19:12:21 +02:00
|
|
|
# Les symboles sont immuables, constants,
|
|
|
|
# réutilisables et représentés en interne
|
|
|
|
# par une valeur entière. Ils sont souvent
|
|
|
|
# utilisés à la place des chaînes de caractères
|
|
|
|
# pour transmettre efficacement des valeurs
|
|
|
|
# spécifiques ou significatives
|
|
|
|
|
|
|
|
:pending.class #=> Symbol
|
|
|
|
|
|
|
|
status = :pending
|
|
|
|
|
|
|
|
status == :pending #=> true
|
|
|
|
|
|
|
|
status == 'pending' #=> false
|
|
|
|
|
|
|
|
status == :approved #=> false
|
|
|
|
|
|
|
|
# Tableaux
|
|
|
|
|
|
|
|
# Ceci est un tableau
|
|
|
|
array = [1, 2, 3, 4, 5] #=> [1, 2, 3, 4, 5]
|
|
|
|
|
|
|
|
# Les tableaux contiennent différents types d'élément.
|
|
|
|
|
|
|
|
[1, "hello", false] #=> [1, "hello", false]
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Les tableaux peuvent être indexés
|
2017-07-11 15:37:49 +02:00
|
|
|
# Trouver la valeur en donnant la position en partant du début (le premier élément est à l'index 0)
|
2013-08-14 19:12:21 +02:00
|
|
|
array[0] #=> 1
|
|
|
|
array[12] #=> nil
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Comme les opérateurs, la syntaxe [var] est juste un raccourci
|
2013-08-14 19:12:21 +02:00
|
|
|
# pour appeler la méthode [] d'un objet
|
|
|
|
array.[] 0 #=> 1
|
|
|
|
array.[] 12 #=> nil
|
|
|
|
|
2017-07-11 15:37:49 +02:00
|
|
|
# On peut compter en partant de la fin avec un index négatif (le dernier élément est à l'index -1)
|
2013-08-14 19:12:21 +02:00
|
|
|
array[-1] #=> 5
|
|
|
|
|
2017-07-11 15:37:49 +02:00
|
|
|
# Avec un index de début et un nombre d'éléments [position, nombre]
|
|
|
|
array[1, 3] #=> [2, 3, 4]
|
2013-08-14 19:12:21 +02:00
|
|
|
|
2017-07-11 15:37:49 +02:00
|
|
|
# Ou avec un intervalle [index de début .. index de fin]
|
2013-08-14 19:12:21 +02:00
|
|
|
array[1..3] #=> [2, 3, 4]
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Ajoutez un élément au tableau comme ceci
|
2013-08-14 19:12:21 +02:00
|
|
|
array << 6 #=> [1, 2, 3, 4, 5, 6]
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Les Hash sont des dictionnaires Ruby contenant des paires de clé/valeur.
|
|
|
|
# Les Hash sont délimitées par des accolades :
|
2013-08-14 19:12:21 +02:00
|
|
|
hash = {'color' => 'green', 'number' => 5}
|
|
|
|
|
|
|
|
hash.keys #=> ['color', 'number']
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Les Hash retournent la valeur
|
|
|
|
# en utilisant la clé associée à la valeur :
|
2013-08-14 19:12:21 +02:00
|
|
|
hash['color'] #=> 'green'
|
|
|
|
hash['number'] #=> 5
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Recherchez une clé inexistante dans une Hash retourne nil :
|
2013-08-14 19:12:21 +02:00
|
|
|
hash['nothing here'] #=> nil
|
|
|
|
|
2013-08-17 10:29:45 +02:00
|
|
|
# Depuis Ruby 1.9, Une syntaxe spécifique est apparue
|
|
|
|
# en utilisant les symboles comme clés :
|
2013-08-14 19:12:21 +02:00
|
|
|
|
|
|
|
new_hash = { defcon: 3, action: true}
|
|
|
|
|
|
|
|
new_hash.keys #=> [:defcon, :action]
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Astuce : Les tableaux et les Hash sont dénombrables
|
2013-08-14 19:12:21 +02:00
|
|
|
# Ils partagent un certain nombre de méthodes pratiques
|
|
|
|
# telle que each, map, count, etc...
|
|
|
|
|
|
|
|
# Structures de contrôle
|
|
|
|
|
|
|
|
if true
|
2017-07-11 15:37:49 +02:00
|
|
|
"si l'instruction est vraie"
|
2013-08-14 19:12:21 +02:00
|
|
|
elsif false
|
2017-07-11 15:37:49 +02:00
|
|
|
"si l'instruction de départ n'était pas vraie, et que cette nouvelle condition est vraie (facultatif)"
|
2013-08-14 19:12:21 +02:00
|
|
|
else
|
2017-07-11 15:37:49 +02:00
|
|
|
"tous les autres cas (il est également facultatif de faire une clause else)"
|
2013-08-14 19:12:21 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
for compteur in 1..5
|
|
|
|
puts "itération #{compteur}"
|
|
|
|
end
|
|
|
|
#=> itération 1
|
|
|
|
#=> itération 2
|
|
|
|
#=> itération 3
|
|
|
|
#=> itération 4
|
|
|
|
#=> itération 5
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# CEPENDANT, l'usage de la boucle for est très rare.
|
|
|
|
# À la place, utilisez la méthode "each"
|
|
|
|
# et passez lui un bloc de code.
|
2013-08-17 10:29:45 +02:00
|
|
|
# Un bloc de code est un ensemble d'instructions
|
|
|
|
# que vous pouvez passer à une methode comme "each".
|
2013-08-17 10:31:54 +02:00
|
|
|
# Les blocs sont similaires aux lambdas, aux fonctions anonymes
|
|
|
|
# ou encore aux closures dans d'autres langages.
|
2013-08-14 19:12:21 +02:00
|
|
|
#
|
2013-08-17 10:29:45 +02:00
|
|
|
# La méthode "each" exécute le bloc de code
|
|
|
|
# pour chaque élément de l'intervalle d'éléments.
|
2013-08-14 19:12:21 +02:00
|
|
|
# Le bloc de code passe un paramètre compteur.
|
2013-08-15 10:45:06 +02:00
|
|
|
# Appelez la méthode "each" avec un bloc de code comme ceci :
|
2013-08-14 19:12:21 +02:00
|
|
|
|
|
|
|
(1..5).each do |compteur|
|
|
|
|
puts "itération #{compteur}"
|
|
|
|
end
|
|
|
|
#=> itération 1
|
|
|
|
#=> itération 2
|
|
|
|
#=> itération 3
|
|
|
|
#=> itération 4
|
|
|
|
#=> itération 5
|
|
|
|
|
|
|
|
# Vous pouvez également mettre un bloc de code entre accolades :
|
|
|
|
(1..5).each {|compteur| puts "itération #{compteur}"}
|
|
|
|
|
|
|
|
# Le contenu des structures de données peut être parcouru
|
|
|
|
# en utilisant la méthode each.
|
|
|
|
array.each do |element|
|
|
|
|
puts "#{element} est une partie du tableau"
|
|
|
|
end
|
|
|
|
hash.each do |cle, valeur|
|
|
|
|
puts "#{cle} est #{valeur}"
|
|
|
|
end
|
|
|
|
|
|
|
|
compteur = 1
|
|
|
|
while compteur <= 5 do
|
|
|
|
puts "itération #{compteur}"
|
|
|
|
compteur += 1
|
|
|
|
end
|
|
|
|
#=> itération 1
|
|
|
|
#=> itération 2
|
|
|
|
#=> itération 3
|
|
|
|
#=> itération 4
|
|
|
|
#=> itération 5
|
|
|
|
|
|
|
|
grade = 'B'
|
|
|
|
|
|
|
|
case grade
|
|
|
|
when 'A'
|
2013-08-15 10:45:06 +02:00
|
|
|
puts "Excellent"
|
2013-08-14 19:12:21 +02:00
|
|
|
when 'B'
|
2013-08-15 12:22:36 +02:00
|
|
|
puts "Plus de chance la prochaine fois"
|
2013-08-14 19:12:21 +02:00
|
|
|
when 'C'
|
|
|
|
puts "Vous pouvez faire mieux"
|
|
|
|
when 'D'
|
|
|
|
puts "C'est pas terrible"
|
|
|
|
when 'F'
|
|
|
|
puts "Vous avez échoué!"
|
|
|
|
else
|
|
|
|
puts "Sytème de notation alternatif"
|
|
|
|
end
|
|
|
|
|
|
|
|
# Fonctions
|
|
|
|
|
|
|
|
def double(x)
|
|
|
|
x * 2
|
|
|
|
end
|
|
|
|
|
|
|
|
# Les fonctions (et tous les blocs de code) retournent
|
|
|
|
# implicitement la valeur de la dernière instruction évaluée
|
|
|
|
double(2) #=> 4
|
|
|
|
|
2015-01-12 14:10:41 +01:00
|
|
|
# Les parenthèses sont facultatives
|
2013-08-15 10:45:06 +02:00
|
|
|
# lorsqu'il n'y a pas d'ambiguïté sur le résultat
|
2013-08-14 19:12:21 +02:00
|
|
|
double 3 #=> 6
|
|
|
|
|
|
|
|
double double 3 #=> 12
|
|
|
|
|
|
|
|
def sum(x,y)
|
|
|
|
x + y
|
|
|
|
end
|
|
|
|
|
|
|
|
# Les paramètres de méthode sont séparés par des virgules
|
|
|
|
sum 3, 4 #=> 7
|
|
|
|
|
|
|
|
sum sum(3,4), 5 #=> 12
|
|
|
|
|
|
|
|
# yield
|
2013-08-15 10:45:06 +02:00
|
|
|
# Toutes les méthodes ont un argument facultatif et implicite
|
|
|
|
# de type bloc de code
|
2013-08-14 19:12:21 +02:00
|
|
|
# il peut être appelé avec le mot clé 'yield'
|
|
|
|
|
|
|
|
def surround
|
|
|
|
puts "{"
|
|
|
|
yield
|
|
|
|
puts "}"
|
|
|
|
end
|
|
|
|
|
|
|
|
surround { puts 'Bonjour tout le monde' }
|
|
|
|
|
|
|
|
# {
|
|
|
|
# Bonjour tout le monde
|
|
|
|
# }
|
|
|
|
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Définissez une classe avec le mot clé 'class'
|
2013-08-14 19:12:21 +02:00
|
|
|
class Humain
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Une variable de classe
|
|
|
|
# est partagée par toutes les instances de cette classe.
|
2013-08-14 19:12:21 +02:00
|
|
|
@@espece = "H. sapiens"
|
|
|
|
|
|
|
|
# Constructeur de classe
|
|
|
|
def initialize(nom, age = 0)
|
2013-08-15 10:45:06 +02:00
|
|
|
# Affectez l'argument à la variable d'instance 'nom'
|
2013-08-14 19:12:21 +02:00
|
|
|
# pour la durée de vie de l'instance de cette classe
|
|
|
|
@nom = nom
|
|
|
|
# Si le paramètre 'age' est absent,
|
|
|
|
# la valeur par défaut définie dans la liste des arguments sera utilisée.
|
|
|
|
@age = age
|
|
|
|
end
|
|
|
|
|
|
|
|
# Une simple méthode setter
|
|
|
|
def nom=(nom)
|
|
|
|
@nom = nom
|
|
|
|
end
|
|
|
|
|
|
|
|
# Une simple méthode getter
|
|
|
|
def nom
|
|
|
|
@nom
|
|
|
|
end
|
|
|
|
|
|
|
|
# Une méthode de classe utilise le mot clé 'self'
|
|
|
|
# pour se distinguer de la méthode d'instance.
|
|
|
|
# La méthode sera alors accessible à partir de la classe
|
|
|
|
# et non pas de l'instance.
|
|
|
|
def self.say(msg)
|
|
|
|
puts "#{msg}"
|
|
|
|
end
|
|
|
|
|
2014-08-19 21:30:31 +01:00
|
|
|
def espece
|
|
|
|
@@espece
|
2013-08-14 19:12:21 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Instanciez une classe
|
2013-08-14 19:12:21 +02:00
|
|
|
jim = Humain.new("Jim Halpert")
|
|
|
|
|
|
|
|
dwight = Humain.new("Dwight K. Schrute")
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Appelez quelques méthodes
|
2013-08-14 19:12:21 +02:00
|
|
|
jim.espece #=> "H. sapiens"
|
|
|
|
jim.nom #=> "Jim Halpert"
|
|
|
|
jim.nom = "Jim Halpert II" #=> "Jim Halpert II"
|
|
|
|
jim.nom #=> "Jim Halpert II"
|
|
|
|
dwight.espece #=> "H. sapiens"
|
|
|
|
dwight.nom #=> "Dwight K. Schrute"
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Appelez la méthode de classe
|
2013-08-14 19:12:21 +02:00
|
|
|
Humain.say("Hi") #=> "Hi"
|
|
|
|
|
|
|
|
# Les classes sont également des objets en Ruby.
|
|
|
|
# Par conséquent, les classes peuvent avoir des variables d'instance.
|
|
|
|
# Les variables de classe sont partagées parmi
|
|
|
|
# la classe et ses descendants.
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Classe parente
|
2013-08-14 19:12:21 +02:00
|
|
|
class Humain
|
|
|
|
@@foo = 0
|
|
|
|
|
|
|
|
def self.foo
|
|
|
|
@@foo
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.foo=(valeur)
|
|
|
|
@@foo = valeur
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-08-15 10:45:06 +02:00
|
|
|
# Classe fille
|
2013-08-14 19:12:21 +02:00
|
|
|
class Travailleur < Humain
|
|
|
|
end
|
|
|
|
|
|
|
|
Humain.foo # 0
|
|
|
|
Travailleur.foo # 0
|
|
|
|
|
|
|
|
Humain.foo = 2 # 2
|
|
|
|
Travailleur.foo # 2
|
|
|
|
|
|
|
|
# Les variables d'instance de classe ne sont pas partagées
|
|
|
|
# avec les classes héritées.
|
|
|
|
|
|
|
|
class Humain
|
|
|
|
@bar = 0
|
|
|
|
|
|
|
|
def self.bar
|
|
|
|
@bar
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.bar=(valeur)
|
|
|
|
@bar = valeur
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class Docteur < Humain
|
|
|
|
end
|
|
|
|
|
|
|
|
Humain.bar # 0
|
|
|
|
Docteur.bar # nil
|
|
|
|
|
|
|
|
```
|