Des couleurs en HTML⚓︎

Une couleur en HTML est représentée par une chaine de caractères de sept caractères dont le premier est '#' ; les six autres, groupés 2 par 2 forment 3 entiers en hexadécimal (base 16). Le premier entier est la quantité de rouge ; le deuxième la quantité de vert et le troisième est la quantité de bleu. Ces trois valeurs hexadécimales sont comprises entre "00" et "FF".

Exemples

Voici quelques couleurs en HTML :

  • "#C0392B" une sorte de brun rouge,
  • "#00FF00" du vert uniquement,
  • "#000000" du noir.

Une autre façon de représenter une couleur est par un triplet \((r, v, b)\) de valeurs décimales comprises entre \(0\) et \(255\) : \(r\) est la quantité de rouge, \(v\) la quantité de vert et \(b\) la quantité de bleu.

On souhaite écrire une fonction html_vers_rvb qui prend une chaine de caractères représentant une couleur HTML en paramètre et qui renvoie le triplet de décimaux \((r, v, b)\) représentant la même couleur.

On rappelle les valeurs décimales des 16 chiffres hexadécimaux sont : "0" vaut \(0\), jusqu'à "9" qui vaut \(9\), puis "A" vaut \(10\), "B" vaut \(11\) ainsi de suite jusqu'à 'F' qui vaut \(15\).

Pour calculer la valeur décimale d'un nombre hexadécimal de deux chiffres \((ab)_{16}\), on fera le produit de la valeur décimale du chiffre des seizaines \(a\) par \(16\) plus la valeur décimale du chiffre des unités \(b\).

Indications
  • Le nombre hexadécimal "B5" vaut \(11\times 16 + 5\) soit \(181\) en décimal.

  • "00" vaut \(0\times 16 + 0\) soit \(0\).

  • En prenant couleur = "#F307D6", couleur[1] renvoie 'F'.

Il est demandé de :

  1. compléter le dictionnaire HEX_DEC qui donne les valeurs décimales des chiffres hexadécimaux ;

  2. écrire la fonction hex_int qui prend deux chaines d'un caractère a et b en paramètres (de sorte que \((ab)_{16}\) est un entier en hexadécimal) et renvoie la valeur décimale associée ;

Exemples
🐍 Console Python
>>> hex_int('B', '5')
181
>>> hex_int('0', '0')
0
###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
Tronquer ou non le feedback dans les terminaux (sortie standard & stacktrace / relancer le code pour appliquer)
Si activé, le texte copié dans le terminal est joint sur une seule ligne avant d'être copié dans le presse-papier
Évaluations restantes : 5/5
.128013lS]etdA5fz18umag,_F/=in{ 6)yXqPhcD[(bEsxp4r;C90"ovH+7B3k: *}2030a08090j0q050H0!0B050j0H0H0p0Q090q0J0Q020t030H0h0i0i0j0L0w02060R050h0`0R0r030o111315170 0J02031n1g1q0o1n0 0a0q0S0/0;0?0^0A0q0k0A051E0A090}030*0F05081z0=0@0Q1D1F1H1F091N1P1L090L1o090A0/1a0H0J0j0r0^0%0Q1R1B0Q0d0,080r0j0i081L1-1/1@1T1`1P1}1 0}040!0z0L0R0J0R0H0q1d0r0!0(1+0L0L080B2k1g220r1o0o1)2x1%1(1'1M0a240^1H0r1|2h1L1w1y0:1S2H0q2J0r0R2N1L0J2q1o2v2x2#101.2l2P1^2U0L14050}0!0f2u2(0~2'232*1T2,2.2:0%2?1/2^2v2G0Q2}0j2/020!0X312w0 342{0^37390!0K3d332(353j2:0c3n3f3p3h360R2-382:0u3u2_2)1A2|3z2~3a0V3E3g3H3i3J3B3a0g3N3w3P3y3A3k0O3V2`3X3r020f0P3$3G2Q3Y3K0f2=1h2@3v3%3.3(0f303?323^3-2+3R390f3c3~3e3F3q430}0f3m473o3_423Z4c3t4f404a4j3)3D4m493x3{3M4s3O3`4b3)3U4x3W4z4p0f3#4D4h3I4p0%3+4J414L3K0%3=2#4n4u4A0%3}2%1t2Z1g2N2A0a1(2F3x0B2V201o4(1p4%4#2%4.0(2!4E2+0}0T0G0x0m0C0G0N3n0!4t3X0R0}0p57593.0|020s3u0!5l584y1^0H1=02000y0h0R090M0P5t5v5x3n5f1^5h0Z5e5o1T0i0q0}4O2%5J0^5h0l5k5m5E1T5q0}5A5w0M0f5!5C4f5W5R0}5H4f5n4}5K5M3)5D5Q0Q5S5U5l5*0Q5Y5s5u5#0%5'0M5@5:5+025-2#5/4K0^5L0}4!2@5}5`4m5m6c4Q0^5 640X64666d5_5,5I670Q6f02465P6z6k4V6m5}6q615x0K6t5)5^5G6y6v6B4e6E6v6G3@6I5^6K5B0M0c6O6W6o6w696S6+6B4l6*356Y3 6!6z6$5#0u6)6i6Q6x5.5}6B4r6=3x6@3e6_6v6{5x0V6~326j716b735=4w763X780~7a6+7c0M0g7f2w7h6-725^6B4C7n5g0}5T6l5V6#5r640O7w4|6X7i2@6n356B4I7E5F7G5{7T3x7t0b7O7y6a7S7k4c5O6 6F7Z7I5|7K5Z6L0M0W7(707z7j7B5=3;6u6+7p0t7r357t0N7|7:7~7+804c6h7g7}7H6H7J6`7L7_0C8b7Q8d327#3X6B45836?7;8l7?8n7^6%0G8r847R8u7,3)6V7/8s8k6Z8m7b8o6%0n8I8A8t2w8v3.8x6;8P8J028R3 7y0$3u0t4W3X0Y0}0(0d6.3q0d0}0A080I0m2S098z770}0E953'0}0H080q0e0+2J997F8+8{4u0}0h0r2j089i7Y020v7*6^8T6+8@022q090h0L1f7A6z0r4 5153559s1T5h0D9O3i9b9d9f2S9r6P8c079l5a0}0#9$8%81758e6z5b020U9)4~02505254569Z8s9R9|6+9J029o9q9S6,9#4s0o4`082x2Yab4'1x4)2A2D2y0j1Oae0o4(0 ao0)0+0-02.
  1. écrire la fonction html_vers_rvb en vous servant de la fonction précédente.
Exemples
🐍 Console Python
>>> html_vers_rvb("#C0392B")
(192, 57, 43)
>>> html_vers_rvb("#00FF00")
(0, 255, 0)
>>> html_vers_rvb("#000000")
(0, 0, 0)
###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
Tronquer ou non le feedback dans les terminaux (sortie standard & stacktrace / relancer le code pour appliquer)
Si activé, le texte copié dans le terminal est joint sur une seule ligne avant d'être copié dans le presse-papier
Évaluations restantes : 5/5
.128013[(lbsS]etxph4rd5f1uma"ovg,_/3=in 6k:)y 2Pc030j0c0d0p0z07090H0K070p09090y0q0d0z0f0q020B03090n0o0o0p0i0G020a0r070n0#0r0A030w0+0-0/0;0)0f0203140}170w140)0j0z0s0T0V0X0Z0g0z0t0g071l0g0d0'030O08070c1g0W0Y0q1k1m1o1m0d1u1w1s0d0i150d0g0T0@090f0p0A0Z0I0q1y1i0q0l0Q0c0A0p0o0c1s1R1T1Y1A1#1w1'1)0'040H0J0i0r0f0r090z0`0A0H0M1P0i0i0c0K210}1,0A150w1N2e1K1M1L1t0j1.0Z1o0A1%1~1s1d1f0U1z2o0z2q0A0r2u1s0f27152c2e2I0*1S222w1Z2B0i0.070'0m2b2M0(2L1-2O1A2Q2S0'0I2W1T2Y2c2n0q2%0p2T020x2*2d0)2-2#0Z2:2=0h2^2,2M2.2~0'0k312`332|2/0r2R2;0'0C31182G0}2u2h0j1M2m3b0K2C1*153m163k2K0~2X033s0M2H3a1h1A0D0'0M0l310H2Z2N3H2}0l0'1q0o070v0s0c0i090v0i0s083i2{3R0q0%02063*3G2x2/3U0d3W3;2!3,3.0F0E380H423O3+3?3J02270d0n0i0|3A2+443=1Z3.3:4e2_434n4g3|3?0A3U0c0e0v2z0d3{3Q3?4j4z343^3`4l3F4q4i0'054D3b0o0z2U4N3}0'0b0u3N3P4E023V074S4B4L4%1Z4P2(4)1A3.0b0F4W4H0B4o434Y3b4s4!4u4w0A4y4H4`4T3/4-2}4F4$52454K024M5a4h1A4+2?563-4U4=2I4p4A2P585k3.5e2K5b5h4Q02305f4J4.4U4;414^5p4Z0g4~4x5t0'4k5w5g574!3_595R5D0Z5u5k5i375C5q5E024V4X5x5T4#5O5d5#5z3h5'2.4/5G4?4n534'020F380}3D0c2e2F653l1e3n2h2k2f0p1v680w3m0)6i0N0P0R02.