Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.
Este repositório está arquivado. Você pode visualizar os arquivos e realizar clone, mas não poderá realizar push nem abrir issues e pull requests.

index.rst 2.8 KiB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. Chapitre 8 - Dictionnaires
  2. ==========================
  3. Définition
  4. ----------
  5. Un dictionaire est une _association_ entre des clés et des valeurs.
  6. * Les clés sont uniques
  7. * Les valeurs sont arbitraires
  8. Création de dictionnaires
  9. -------------------------
  10. Avec des accolades: ``{``, ``}`` ::
  11. dictionaire_vide = {}
  12. une_clé_une_valeur = {"a": 42}
  13. deux_clés_deux_valeurs = {"a": 42, "b": 53}
  14. Les clés sont uniques::
  15. {"a": 42, "a": 53} == {"a": 53}
  16. Note: tous les dictionnaires sont truthy, sauf les dictionnaires vides.
  17. Accès aux valeurs
  18. ------------------
  19. Avec ``[]``, comme pour les listes, mais avec une *clé* à la place d'un *index*::
  20. scores = {"john": 10, "bob": 42}
  21. print(scores["john"])
  22. # affiche: 10
  23. print(scores["bob"])
  24. # affiche: 42
  25. print(scores["charlie"])
  26. # erreur: KeyError
  27. Test d'appartenance
  28. ---------------------
  29. Avec ``in``, comme le listes::
  30. scores = {"john": 10, "bob": 42}
  31. print("charlie" in scores)
  32. # affiche: False
  33. Modifier la valeur d'une clé
  34. -----------------------------
  35. Comme pour les listes, avec une assignation::
  36. scores = {"john": 10, "bob": 42}
  37. scores["john"] = 20
  38. print(scores)
  39. # affiche: {"john": 20, "bob": 42}
  40. Créer une nouvelle clé
  41. -----------------------
  42. Même mécanisme que pour la modification des clés existantes::
  43. scores = {"john": 10, "bob": 42}
  44. scores["charlie"] = 30
  45. print(scores)
  46. # affiche: {"john": 20, "bob": 42, "charlie": 30}
  47. *rappel*: ceci ne fonctionne pas avec les listes: on ne peut
  48. pas "créer" de nouveaux éléments dans la liste juste
  49. avec un index::
  50. ma_liste = ["a", "b"]
  51. ma_liste[1] = "c"
  52. print(ma_liste)
  53. # affiche: ["a", "c"]
  54. ma_liste[3] = "d"
  55. # erreur: IndexError
  56. Itérer sur les clés
  57. -------------------
  58. Avec ``for ... in ...``, comme pour les listes::
  59. scores = {"john": 10, "bob": 42}
  60. for nom in scores:
  61. # on assigne la valeur "john" à la variable `nom`, puis "bob"
  62. score_associé_au_nom = scores[nom]
  63. # on assigne la valeur 10 puis la valeur 42 à la variable
  64. # score_associé_au_nom
  65. print(nom, score_associé_au_nom)
  66. .. code-block::
  67. john 10
  68. bob 42
  69. del
  70. ---
  71. Détruire une clé
  72. +++++++++++++++++
  73. Avec ``del`` - un nouveau mot-clé::
  74. scores = {"john": 10, "bob": 42}
  75. del scores["bob"]
  76. print(scores)
  77. # affiche: {"john": 10}
  78. Détruire un élément d'une liste
  79. ++++++++++++++++++++++++++++++++
  80. Aussi avec ``del``::
  81. fruits = ["pomme", "banane", "poire"]
  82. del fruits[1]
  83. print(fruits)
  84. # affiche: ["pomme", "poire"]
  85. Détruire une variable
  86. +++++++++++++++++++++
  87. Encore et toujours ``del``::
  88. mon_entier = 42
  89. mon_entier += 3
  90. print(mon_entier)
  91. # affiche: 45
  92. del mon_entier
  93. mon_entier += 1
  94. # erreur: NameError