<?xml version="1.0" encoding="UTF-8"?>
<quiz>
<question type="category">
  <category>
    <text>$course$/QCM de NSI/Première/Modules Python</text>
  </category>
  <info format="html">
    <text><![CDATA[<p>Notion de module, importation (import,<br/>
from ... import), modules standards (math,<br/>
random, os, csv...), création de ses propres<br/>
modules, espaces de noms, alias.</p>]]></text>
  </info>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q01 : Qu'est-ce qu'un module ?</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>En Python, qu'est-ce qu'un <strong>module</strong> ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>La modularité est un principe central en génie<br/>
logiciel : organiser le code en unités<br/>
cohérentes et réutilisables, plutôt qu'un seul<br/>
gros fichier.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Un type de données</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : un module est un fichier, pas un<br/>
type.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Un fichier .py contenant des fonctions, des classes ou des constantes réutilisables</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : un module regroupe du code<br/>
réutilisable. On peut importer un module<br/>
dans un autre programme pour utiliser ses<br/>
fonctions sans les recoder.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Une boucle imbriquée</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Une boucle imbriquée est<br/>
une construction de<br/>
contrôle interne à une<br/>
fonction. Un module est<br/>
au contraire une unité<br/>
d'organisation du code,<br/>
stockée dans un fichier.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Une variable globale</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Une variable globale est<br/>
une variable accessible<br/>
dans tout un programme.<br/>
Un module, lui, est une<br/>
unité d'organisation du<br/>
code, contenue dans un<br/>
fichier source distinct.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q02 : Import</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Comment <strong>importer</strong> le module math en Python ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>import math charge le module et le rend<br/>
accessible sous le nom math. Pour des<br/>
fonctions précises sans préfixe :<br/>
from math import sqrt.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>require math</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : c'est la syntaxe JavaScript / Ruby.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>use math</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : c'est la syntaxe Perl.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>include math</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : c'est la syntaxe C/C++.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>import math</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : l'instruction import rend<br/>
accessible le contenu du module via le<br/>
préfixe math. (ex. math.sqrt(2)).</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q03 : Utilisation après import</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Après import math, comment appelle-t-on la<br/>
fonction sqrt (racine carrée) ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Préfixe = <strong>espace de noms</strong>. Évite les<br/>
conflits si plusieurs modules ont des<br/>
fonctions de même nom.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>math-&gt;sqrt(2)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : -&gt; est la syntaxe Perl/PHP.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>math.sqrt(2)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : on utilise le préfixe<br/>
module.fonction.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>sqrt(2)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : sans préfixe math., Python ne<br/>
connaît pas sqrt.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>math::sqrt(2)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : :: est la syntaxe C++ ou Ruby.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q04 : from import</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Que fait from math import sqrt ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Variantes : from math import sqrt, pi (deux<br/>
noms) ou from math import * (tout, mais à<br/>
éviter, pollue l'espace de noms).</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Importe tout le module math</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : on importe seulement sqrt.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Importe seulement la fonction sqrt, qui devient appelable directement comme sqrt(2)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : utile quand on n'a besoin<br/>
que de quelques fonctions et qu'on veut<br/>
éviter le préfixe.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Cela ne fonctionne pas</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : syntaxe valide.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Renomme math en sqrt</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Le renommage à<br/>
l'importation utilise<br/>
le mot-clé as, par<br/>
exemple import math as<br/>
m. La syntaxe from ...<br/>
import ne renomme rien,<br/>
elle expose un symbole<br/>
précis.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q05 : Constante pi</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Comment obtenir la valeur de π en Python ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Constantes utiles dans math : math.pi,<br/>
math.e, math.inf, math.nan.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>PI</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas de constante PI en majuscules.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>math.pi (après import math)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : math.pi ≈<br/>
3.141592653589793. Pour la précision<br/>
maximale flottante.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>3.14</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>C'est une approximation, mais le module<br/>
math offre une valeur plus précise.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>pi</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pi n'est pas une variable<br/>
globale par défaut. Il faut l'importer.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q06 : Module random</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Quel module de la bibliothèque standard permet<br/>
de générer des nombres aléatoires ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>random est très utilisé en NSI Première<br/>
pour les jeux, les simulations, le tirage<br/>
aléatoire. Pour des usages cryptographiques,<br/>
préférer secrets (plus sûr).</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>numpy</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Existe et a un sous-module random, mais<br/>
ce n'est pas la bibliothèque <strong>standard</strong><br/>
(à installer séparément).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>math</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : math est pour les fonctions<br/>
mathématiques classiques.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>random</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : random.randint(a, b),<br/>
random.choice(liste), random.shuffle(...),<br/>
etc.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>stochastic</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas de module standard de ce nom.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q07 : Tirage aléatoire</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Que fait random.randint(1, 6) ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Distinction subtile : random.randint(a, b)<br/>
→ bornes <strong>incluses</strong> ; random.randrange(a,<br/>
b) → b <strong>exclue</strong> (comme range).</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Renvoie 6 (le maximum)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : c'est aléatoire, pas<br/>
systématiquement le max.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Renvoie une liste de 6 éléments</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : un seul entier.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Renvoie un nombre flottant entre 1 et 6</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : randint renvoie un <strong>entier</strong>.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Renvoie un entier aléatoire entre 1 et 6, inclus</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : simule un dé à 6 faces.<br/>
Attention : contrairement à range, les<br/>
deux bornes sont <strong>incluses</strong>.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q08 : Alias avec as</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Que fait import numpy as np ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Convention de la communauté Python : on<br/>
utilise toujours les mêmes alias pour les<br/>
grandes bibliothèques scientifiques.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Importe deux modules numpy et np</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : un seul module avec deux noms.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Importe numpy mais le renomme en np</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : as np crée un <strong>alias</strong>.<br/>
Pratique pour les modules à nom long.<br/>
Convention : numpy as np,<br/>
pandas as pd, matplotlib.pyplot as plt.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Erreur de syntaxe</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : la syntaxe import x as y est<br/>
valide.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Importe seulement np (pas numpy au complet)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : c'est tout numpy qui est importé,<br/>
juste accessible via np.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q09 : Bibliothèque standard</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Que signifie « bibliothèque standard de Python » ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Pour les modules <strong>externes</strong> (numpy, pandas,<br/>
matplotlib, requests...), il faut installer<br/>
avec pip install nom_du_module.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Une norme ISO obligatoire</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas de normalisation officielle.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>La documentation officielle</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Confusion : la bibliothèque standard est un<br/>
<strong>ensemble de modules</strong>, pas la doc.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Les modules livrés avec Python, disponibles sans installation supplémentaire</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : math, random, os,<br/>
sys, csv, json, datetime,<br/>
urllib... tous prêts à l'emploi. C'est<br/>
l'une des grandes forces de Python<br/>
(« batteries included »).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>La bibliothèque physique d'Anthropic</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>La bibliothèque standard<br/>
de Python est un ensemble<br/>
de modules logiciels<br/>
maintenu par la Python<br/>
Software Foundation. Elle<br/>
n'a aucun lien avec<br/>
Anthropic ni avec une<br/>
collection physique.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q10 : Exemple complet</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>`<code>python<br/>
import math<br/>
print(math.sqrt(16))<br/>
</code>`<br/>
Que produit ce code ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Pour un entier, utiliser int(math.sqrt(16))<br/>
ou math.isqrt(16) (entier directement, sans<br/>
passer par un flottant).</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Affiche 16.0</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : sqrt calcule la <strong>racine</strong>, pas<br/>
l'identité.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Affiche 4.0</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : math.sqrt(16) = 4.0<br/>
(flottant, même pour un carré parfait).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Lève une erreur</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : code valide.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Affiche 4</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Pas tout à fait : sqrt renvoie un<br/>
<strong>flottant</strong> (4.0), pas un entier.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q11 : Espace de noms</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Pourquoi est-il <strong>déconseillé</strong> d'utiliser<br/>
from math import * ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Bonne pratique : import math (préfixe) ou<br/>
from math import sqrt, pi (sélectif).<br/>
Éviter from x import * sauf pour des<br/>
modules conçus pour cela.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Parce que c'est trop lent</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : performance équivalente.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Parce que cela importe tous les noms dans le scope global, ce qui peut masquer des variables/fonctions existantes (collisions)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : par exemple, si vous<br/>
aviez une variable pow, elle serait<br/>
écrasée par math.pow. Source de bugs<br/>
subtils.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Parce que c'est interdit par Python</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : possible mais déconseillé.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Parce que cela ne fonctionne pas</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : la syntaxe est valide.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q12 : Créer son module</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Comment créer son propre module<br/>
mes_outils.py et l'importer ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Cette simplicité est l'un des grands atouts<br/>
de Python pour la modularité. Un projet est<br/>
naturellement organisé en plusieurs fichiers<br/>
.py.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Il faut un mot-clé module dans le fichier</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : aucun mot-clé spécial.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Il faut compiler le module avant de l'importer</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : Python est interprété, pas de<br/>
compilation explicite.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Créer un fichier mes_outils.py contenant des fonctions, puis dans un autre fichier du même répertoire : import mes_outils</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : tout fichier .py est un<br/>
module. Aucune déclaration spéciale n'est<br/>
nécessaire.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Il faut publier le module sur PyPI</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : seulement pour le partage public.<br/>
Localement, il suffit du fichier.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q13 : Import une seule fois</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Si l'on écrit import math deux fois dans le<br/>
même programme, que se passe-t-il ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Pour vraiment recharger un module modifié<br/>
(rare), utiliser importlib.reload. Sinon,<br/>
le cache simplifie la vie.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Cela lève une erreur</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas d'erreur.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Le module est dupliqué en mémoire</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : un seul exemplaire en mémoire.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Le module n'est chargé qu'une seule fois ; la deuxième instruction ne fait rien</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : Python tient un cache des<br/>
modules déjà chargés (sys.modules).<br/>
Performance optimale.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Le module est rechargé à chaque fois (lent)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : Python optimise.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q14 : Choix aléatoire</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Quelle fonction du module random permet de<br/>
choisir un élément au hasard dans une liste ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Autres fonctions utiles : random.choices<br/>
(avec poids), random.sample (sans<br/>
remise), random.shuffle (mélange en place).</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>random.select(liste)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas de fonction de ce nom.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>random.random(liste)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : random.random() renvoie un<br/>
flottant entre 0 et 1, sans paramètre.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>random.choice(liste)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : choice renvoie un<br/>
élément aléatoire de la liste (chaque<br/>
élément a la même probabilité d'être<br/>
choisi).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>random.pick(liste)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : la fonction n'a pas ce nom.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q15 : Bloc principal</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Que signifie l'idiome if __name__ == "__main__": ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Schéma standard pour rendre un fichier<br/>
réutilisable comme module sans déclencher<br/>
ses tests/démos lors de l'import.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Que le programme est sans bug</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>La présence de cette<br/>
condition n'apporte<br/>
aucune garantie sur la<br/>
correction du programme.<br/>
Elle distingue uniquement<br/>
un script exécutable d'un<br/>
module importable.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Que le bloc s'exécute uniquement quand le fichier est lancé directement, pas quand il est importé comme module</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : __name__ vaut<br/>
"__main__" en exécution directe et le<br/>
nom du module en import. Cet idiome<br/>
permet d'avoir des fichiers à la fois<br/>
modules <strong>et</strong> scripts.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Que le programme est en mode débogage</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Aucun mode de débogage<br/>
n'est associé à cette<br/>
construction. La variable<br/>
__name__ reflète le<br/>
contexte d'exécution :<br/>
script lancé directement<br/>
ou module importé.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Que la fonction main doit être définie</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Pas tout à fait : main n'est qu'une<br/>
convention, pas obligatoire.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q16 : Documentation interactive</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Comment obtenir l'aide d'une fonction d'un<br/>
module en mode interactif ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Autre forme utile en interactif : ?math.sqrt<br/>
(en IPython/Jupyter). Et toujours la<br/>
documentation officielle :<br/>
docs.python.org.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>help(math.sqrt)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : la fonction native help<br/>
affiche la docstring et les annotations<br/>
de la fonction. Très utile en exploration.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>man math.sqrt</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : man est une commande Unix.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>info(math.sqrt)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas de fonction info en Python.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>google math.sqrt</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Aucune commande google<br/>
n'existe dans la console<br/>
Python. La documentation<br/>
intégrée s'obtient avec<br/>
la fonction help, qui<br/>
affiche directement la<br/>
docstring associée.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q17 : Importation sélective</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Quel code utilise pi correctement après<br/>
from math import pi ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>import math → math.pi ; from math import<br/>
pi → pi. Choisir selon ses préférences.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>math.pi</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : avec from ... import, on<br/>
n'utilise <strong>pas</strong> le préfixe.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>pi</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : pi est importé<br/>
directement dans l'espace de noms local.<br/>
On peut écrire 2 * pi.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>import.pi</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : syntaxe invalide.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>from.pi</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : syntaxe invalide.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q18 : Conflit de noms</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>``python<br/>
from math import sqrt</p>
<p>def sqrt(x):<br/>
    return x ** 0.5</p>
<p>print(sqrt(16))<br/>
``<br/>
Quelle fonction est appelée ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Bonne pratique : éviter de redéfinir des<br/>
noms importés. Si on doit le faire, l'import<br/>
avec préfixe (import math) protège.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>La fonction de math (4.0)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : la définition locale <strong>écrase</strong><br/>
l'import.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Les deux fonctions sont appelées</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : un seul nom à la fois.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>La fonction sqrt définie localement, qui retourne aussi 4.0 puisqu'elle calcule également la racine carrée</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : la dernière définition<br/>
gagne. Les deux fonctions calculent la<br/>
même chose (la racine carrée) et donnent<br/>
donc le même résultat sur cet exemple,<br/>
mais en général c'est un piège : la<br/>
définition locale masque silencieusement<br/>
l'import.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Erreur : conflit de noms</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas d'erreur en Python (qui<br/>
écrase silencieusement).</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q19 : Reproductibilité</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Pourquoi utilise-t-on random.seed(42) ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Important : random n'est pas<br/>
cryptographiquement sûr (utiliser secrets<br/>
pour cela). Mais pour les simulations et<br/>
jeux, c'est parfait.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Pour rendre les tirages plus aléatoires</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : c'est l'inverse, on les rend<br/>
déterministes.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Pour accélérer le générateur</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas d'effet sur la performance.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Pour rendre les tirages reproductibles : avec la même graine, on obtient toujours la même séquence</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : utile pour le débogage,<br/>
les tests, la reproductibilité<br/>
scientifique.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Pour générer le nombre 42</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : seed initialise le générateur<br/>
aléatoire, ne génère rien directement.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q20 : Modules variés</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Lequel de ces modules de la bibliothèque<br/>
standard est utilisé pour manipuler des<br/>
<strong>fichiers JSON</strong> ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Modules NSI utiles : math, random, csv,<br/>
json, time, datetime, os, sys,<br/>
string.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>json</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : fonctions principales<br/>
json.dumps (objet → chaîne JSON) et<br/>
json.loads (chaîne JSON → objet<br/>
Python).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>csv</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>C'est pour les fichiers CSV.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>math</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Pour les fonctions mathématiques.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>os</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>C'est pour interagir avec le système<br/>
d'exploitation.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q21 : Installer un module externe</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Comment installe-t-on un module externe (par<br/>
exemple numpy) qui n'est pas dans la<br/>
bibliothèque standard ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>pip gère aussi les dépendances entre<br/>
modules. Pour un projet, un fichier<br/>
requirements.txt listant les dépendances<br/>
facilite la reproductibilité.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Avec la commande pip install numpy (dans le terminal)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : pip est l'outil<br/>
d'installation officiel de Python.<br/>
pip install nom télécharge depuis PyPI<br/>
(Python Package Index).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Avec download numpy dans Python</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas de fonction de ce nom.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Avec import numpy</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : import charge un module <strong>déjà<br/>
installé</strong>, ne l'installe pas.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Il faut le télécharger manuellement et le copier</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>C'était possible historiquement, mais<br/>
pip automatise tout cela.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q22 : Package</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Quelle est la différence entre un <strong>module</strong> et<br/>
un <strong>package</strong> en Python ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>En NSI Première, on travaille surtout avec<br/>
des modules simples. Les packages sont une<br/>
structuration plus avancée pour les gros<br/>
projets.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Un module est plus rapide</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas de différence de<br/>
performance.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Un package est un module compilé</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : pas de compilation Python directe.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Aucune</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : ce sont deux notions différentes.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Un module est un fichier .py ; un package est un répertoire contenant plusieurs modules (et un fichier __init__.py)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : numpy, pandas, etc.<br/>
sont des packages (répertoires). On<br/>
accède à leurs sous-modules avec<br/>
numpy.linalg, etc.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q23 : Pollution du namespace</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Pourquoi le code suivant peut-il être<br/>
problématique ?<br/>
`<code>python<br/>
from random import <em><br/>
from math import </em><br/>
</code>`</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Maxime PEP 20 : « Explicit is better than<br/>
implicit. » Préférer les imports explicites<br/>
pour la traçabilité.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Parce que les deux modules peuvent avoir des fonctions de même nom (par exemple pow), et le second import écrase silencieusement le premier</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : conflit silencieux,<br/>
source de bugs très difficiles à<br/>
diagnostiquer. À éviter dans tout code<br/>
sérieux.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Parce que c'est trop lent</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : performance acceptable.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Parce que l'on ne peut pas importer plusieurs modules</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : on peut importer autant qu'on veut.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Parce que math doit être importé avant random</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : aucun ordre imposé.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q24 : Ordre des imports</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Dans un fichier Python bien organisé, où<br/>
placer les import ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Convention de lecture : voir tout de suite<br/>
les dépendances en haut du fichier.<br/>
Beaucoup d'éditeurs (et d'analyseurs<br/>
statiques) vérifient cet ordre.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Dans une fonction main</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Possible (chargement paresseux) mais<br/>
exceptionnel. Convention : en haut.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>À la fin du fichier</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : tous les noms importés ne seraient<br/>
pas disponibles avant.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>N'importe où dans le fichier</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Techniquement possible, mais déconseillé.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>En haut du fichier, regroupés (standards / externes / locaux)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : convention PEP 8 :<br/>
d'abord les imports standards (math,<br/>
os...), puis les externes (numpy,<br/>
pandas...), puis les modules locaux du<br/>
projet, séparés par une ligne vide.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q25 : Synthèse</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Parmi les affirmations suivantes, laquelle est<br/>
<strong>fausse</strong> ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Le cache de modules garantit la cohérence<br/>
(un seul exemplaire en mémoire) et la<br/>
performance.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>from math import pi importe la constante pi sans préfixe</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Vrai : importation sélective.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>La bibliothèque standard de Python contient des modules pour les fichiers, le réseau, les dates, le hasard, etc.</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Vrai : « batteries included », l'une des<br/>
forces de Python.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>Tout module importé est systématiquement rechargé à chaque exécution du programme</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Faux (donc bonne réponse) : Python met<br/>
en cache les modules dans sys.modules.<br/>
Un module n'est chargé <strong>qu'une seule<br/>
fois</strong> par exécution, même si on l'importe<br/>
dans plusieurs fichiers.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>import math rend les fonctions accessibles via le préfixe math.</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Vrai : c'est le rôle de import.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q26 : random.random et random.randint</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Quelle est la différence entre random.random() et<br/>
random.randint(a, b) ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Pour mémoriser : random.random() → [0 ; 1[<br/>
(flottant) ; random.randint(a, b) → [a ; b]<br/>
(entier) ; random.randrange(a, b) → [a ; b[<br/>
(entier) ; random.choice(seq) → un élément de<br/>
la séquence. Pour la reproductibilité d'un tirage,<br/>
fixer random.seed(...) au début du programme.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>Les deux renvoient un entier compris entre 0 et 1</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : la fonction random.random() renvoie un<br/>
flottant, pas un entier. Et randint(a, b) peut<br/>
renvoyer n'importe quel entier de l'intervalle, pas<br/>
seulement 0 ou 1.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>random.random() renvoie un flottant tiré uniformément dans [0 ; 1[ ; random.randint(a, b) renvoie un entier tiré uniformément dans [a ; b] (bornes incluses)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : random.random() produit un<br/>
flottant inférieur à 1, tandis que<br/>
random.randint(a, b) est l'unique fonction du<br/>
module à inclure les <strong>deux</strong> bornes (alors que<br/>
la plupart des intervalles Python excluent la<br/>
borne droite).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>La fonction random.randint(a, b) exclut la borne b</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : c'est précisément la particularité de<br/>
randint parmi les fonctions du module : la borne<br/>
droite est <strong>incluse</strong>. Pour exclure la borne, il<br/>
faudrait utiliser random.randrange(a, b).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>random.random() renvoie l'heure courante ; random.randint lit la mémoire</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : aucune des deux fonctions n'est liée à<br/>
l'heure ni à la mémoire. Elles produisent toutes<br/>
deux des valeurs pseudo-aléatoires.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q27 : Fonctions du module math</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>Parmi les expressions suivantes, laquelle ne renvoie<br/>
<strong>pas</strong> 5 après l'instruction import math ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Quelques fonctions usuelles du module math :<br/>
sqrt (racine carrée), floor et ceil (arrondis<br/>
bas et haut), log (logarithme népérien),<br/>
log10 (logarithme décimal), exp (exponentielle),<br/>
sin/cos/tan (trigonométrie en radians).<br/>
Constantes : math.pi, math.e, math.inf.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>math.ceil(4.3)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>La fonction ceil arrondit vers le haut. Pour<br/>
4{,}3, le résultat est 5.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>math.log(100)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : math.log calcule le logarithme<br/>
<strong>naturel</strong> par défaut, pas le logarithme<br/>
décimal. On a \ln(100) \approx 4{,}605, et non<br/>
5. Pour le logarithme en base 10, il faut<br/>
écrire math.log10(100) ou<br/>
math.log(100, 10).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>math.sqrt(25)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>La racine carrée de 25 vaut bien 5. Cette<br/>
expression renvoie donc 5 (au flottant<br/>
5{,}0 près).</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>math.floor(5.7)</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>La fonction floor arrondit vers le bas (partie<br/>
entière inférieure). Pour 5{,}7, le résultat<br/>
est 5.</p>]]></text>
    </feedback>
  </answer>
</question>

<question type="multichoice">
  <name>
    <text>Modules Python — Q28 : Mesurer une durée d'exécution</text>
  </name>
  <questiontext format="html">
    <text><![CDATA[<p>On souhaite mesurer la durée d'exécution d'une<br/>
portion de code. Quelle structure utilise le module<br/>
time de manière correcte ?</p>]]></text>
  </questiontext>
  <generalfeedback format="html">
    <text><![CDATA[<p>Pour des mesures plus précises ou de très courtes<br/>
durées, préférer time.perf_counter() à<br/>
time.time(). Pour comparer la performance de<br/>
plusieurs implémentations, le module timeit est<br/>
adapté : il exécute le code plusieurs fois et<br/>
atténue les fluctuations.</p>]]></text>
  </generalfeedback>
  <defaultgrade>1.0</defaultgrade>
  <penalty>0.0</penalty>
  <hidden>0</hidden>
  <single>true</single>
  <shuffleanswers>true</shuffleanswers>
  <answernumbering>abc</answernumbering>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>`<code>python<br/>
import time<br/>
duree = time.mesure(code)<br/>
</code>`</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : aucune fonction time.mesure n'existe.<br/>
Pour mesurer du code de manière plus fine, on<br/>
utilise plutôt le module dédié timeit.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>`<code>python<br/>
import time<br/>
duree = time.now()<br/>
</code>`</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : la fonction time.now() n'existe pas.<br/>
Cette confusion vient peut-être du module<br/>
datetime, qui propose datetime.now() pour<br/>
obtenir un objet date complet.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="0" format="html">
    <text><![CDATA[<p>`<code>python<br/>
import time<br/>
duree = time.sleep(10)<br/>
</code>`</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Erreur : time.sleep(10) met le programme en<br/>
pause pendant 10 secondes. Cette fonction ne<br/>
mesure rien : elle attend le délai indiqué et<br/>
renvoie None.</p>]]></text>
    </feedback>
  </answer>
  <answer fraction="100" format="html">
    <text><![CDATA[<p>`<code>python<br/>
import time<br/>
debut = time.time()<br/>
# ... code à mesurer ...<br/>
duree = time.time() - debut<br/>
</code>`</p>]]></text>
    <feedback format="html">
      <text><![CDATA[<p>Bonne réponse : time.time() renvoie le nombre<br/>
de secondes écoulées depuis le 1^{\text{er}}<br/>
janvier 1970. La différence entre deux<br/>
appels donne la durée écoulée en secondes<br/>
(avec une précision de l'ordre de la<br/>
microseconde sur les systèmes modernes).</p>]]></text>
    </feedback>
  </answer>
</question>

</quiz>
