Metadata-Version: 2.4
Name: elrahpy
Version: 0.1.5
Summary: Package pour renforcer mes compétences, améliorer ma productivité et partager mon expertise avec la communauté 
Home-page: https://github.com/Harlequelrah/Library-ElrahPy
Author: Harlequelrah
Author-email: maximeatsoudegbovi@example.com
License: LGPL-3.0-only
Requires-Python: >=3.10
Description-Content-Type: text/markdown
Requires-Dist: numpy>=1.18.0
Requires-Dist: turtle
Requires-Dist: python-dateutil
Dynamic: author
Dynamic: author-email
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: license
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

# Description

Passionné par la programmation et le développement en Python, je crée une bibliothèque personnalisée pour renforcer mes compétences, améliorer ma productivité et partager mon expertise avec la communauté.

# Installation

- **Avec GitHub :**

  ```bash
  git clone https://github.com/Harlequelrah/Library-harlequelrah_py
  ```

- **Avec pip :**

  ```bash
  pip install harlequelrah_py
  ```

# Documentation

Ce package contient plusieurs modules utiles pour divers calculs et manipulations de données. Voici un aperçu de leurs fonctionnalités.

## Module integer

### 1. Sous Module `base_converter`

Le module `base_converter` contient des fonctions pour effectuer des conversions de base numérique.

- **`binary(x)`** : Convertit un nombre entier en une chaîne de caractères représentant sa valeur en binaire sans le préfixe `0b`.

  ```python
  from harlequelrah_py.base_converter import binary

  result = binary(10)  # Résultat : 1010
  ```

  - **Paramètre :**
    - `x` (int) : Le nombre entier à convertir en binaire.
  - **Retourne :**
    - `int` : La représentation binaire sans le préfixe `0b`.

- **`base_format(n, f)`** : Convertit un nombre entier `n` en fonction de la base spécifiée par `f`.

  ```python
  from harlequelrah_py.base_converter import base_format

  result_bin = base_format(10, "b")  # Résultat : "1010"
  result_hex = base_format(10, "h")  # Résultat : "a"
  result_dec = base_format(10, "d")  # Résultat : "10"
  ```

  - **Paramètres :**
    - `n` (int) : Le nombre entier à convertir.
    - `f` (str) : Le format de base à utiliser pour la conversion. Peut prendre les valeurs suivantes :
      - `"b"` : Convertit `n` en binaire.
      - `"h"` : Convertit `n` en hexadécimal.
      - `"d"` : Convertit `n` en décimal.

### 2. Sous Module `math_primes`

Le module `math_primes` contient des fonctions pour effectuer des opérations liées aux nombres premiers et aux diviseurs.

- **`prem(nbr)`** : Vérifie si un nombre est premier.

  ```python
  from harlequelrah_py.math_primes import prem

  result = prem(7)  # Résultat : True
  ```

  - **Paramètre :**
    - `nbr` (int) : Le nombre entier à vérifier.
  - **Retourne :**
    - `bool` : `True` si `nbr` est premier, sinon `False`.

- **`prd_fct(nbr)`** : Retourne un dictionnaire des facteurs premiers d'un nombre.

  ```python
  from harlequelrah_py.math_primes import prd_fct

  result = prd_fct(18)  # Résultat : {2: 1, 3: 2}
  ```

  - **Paramètre :**
    - `nbr` (int) : Le nombre entier à factoriser.
  - **Retourne :**
    - `dict` : Dictionnaire où les clés sont les facteurs premiers et les valeurs sont leurs puissances.

- **`nbr_div(nbr)`** : Calcule le nombre de diviseurs d'un nombre.

  ```python
  from harlequelrah_py.math_primes import nbr_div

  result = nbr_div(36)  # Résultat : 9
  ```

  - **Paramètre :**
    - `nbr` (int) : Le nombre entier à analyser.
  - **Retourne :**
    - `int` : Nombre total de diviseurs.

- **`list_div(nbr)`** : Retourne la liste des diviseurs d'un nombre.

  ```python
  from harlequelrah_py.math_primes import list_div

  result = list_div(36)  # Résultat : [1, 2, 3, 4, 6, 9, 12, 18, 36]
  ```

  - **Paramètre :**
    - `nbr` (int) : Le nombre entier dont on veut la liste des diviseurs.
  - **Retourne :**
    - `list` : Liste des diviseurs triée en ordre croissant.

### 3. Sous Module `math_utils`

Le module `math_utils` contient des fonctions utilitaires mathématiques.

- **`fibonacci(n)`** : Génère la séquence de Fibonacci jusqu'à une limite donnée.

  ```python
  from harlequelrah_py.math_utils import fibonacci

  result = fibonacci(10)  # Résultat : [0, 1, 1, 2, 3, 5, 8]
  ```

  - **Paramètre :**
    - `n` (int) : La limite supérieure pour générer la séquence de Fibonacci.
  - **Retourne :**
    - `list` : Liste contenant la séquence de Fibonacci jusqu'à `n`.

- **`fct(n)`** : Calcule le factoriel d'un nombre.

  ```python
  from harlequelrah_py.math_utils import fct

  result = fct(5)  # Résultat : 120
  ```

  - **Paramètre :**
    - `n` (int) : Le nombre entier pour lequel on veut calculer le factoriel.
  - **Retourne :**
    - `int` : Le factoriel de `n`.

## Module date

### 1. Sous-module `clock`

Le sous-module `clock` contient des fonctions pour la gestion des dates et des heures.

- **is_bisectile(year)** : Renvoie `True` si c'est une année bissextile et `False` sinon.

  ```python
  from harlequelrah_py.date.clock import is_bisectile

  result = is_bisectile(2020)  # Résultat : True
  ```

  - **Paramètre :**
    - `year` (int) : L année pour laquelle on veut vérifier si elle est bisectile
  -**Retourne:**
    - `bool` : True si l'année est bissextile, sinon False.

- **interval(birthday_year, birthday_month, birthday_day, type=None) :** Renvoie un intervalle de temps d'une date à aujourd'hui.

```python
from harlequelrah_py.date.clock import interval

result_years = interval(1990, 5, 15, "year")  # Résultat : (nombre d'années depuis 1990-05-15)
result_months = interval(1990, 5, 15, "month")  # Résultat : (nombre de mois depuis 1990-05-15)
result_days = interval(1990, 5, 15, "day")  # Résultat : (nombre de jours depuis 1990-05-15)
```

  - **Paramètres :**
    - `birthday_year` (int) : L'année de naissance.
    - `birthday_month` (int) : Le mois de naissance.
    - `birthday_day` (int) : Le jour de naissance.
    - `type` (str, optionnel) : Le type d'intervalle à renvoyer. Peut prendre les valeurs suivantes :
      - "year" ou "y" : Renvoie l'intervalle en années.
      - "month" ou "m" : Renvoie l'intervalle en mois.
      - "day" ou "d" : Renvoie l'intervalle en jours.
  - **Retourne :**
    - `int` ou `None` : Le nombre d'années, de mois ou de jours selon le type spécifié, ou None si le type n'est pas reconnu.

## Module files

### Sous-module myfiles

Le sous-module `myfiles` contient des fonctions pour gérer les opérations sur les fichiers.

- **recopie(ficher_source, ficher_destination, debit)** : Recopie le contenu d'un fichier source vers un fichier de destination en plusieurs blocs.

  ```python
  from harlequelrah_py.files.myfiles import recopie

  recopie("source.txt", "destination.txt", 1024)  # Copie le contenu de source.txt à destination.txt
  ```

  - **Paramètres :**
    - `ficher_source` (str) : Le chemin du fichier source à recopier.
    - `ficher_destination` (str) : Le chemin du fichier de destination.
    - `debit` (int) : Le nombre de caractère à recopier à chaque fois.
  - **Retourne :**
    - `None` : La fonction ne retourne rien.

  - **filereset(file)** : Efface le contenu d'un fichier.

  ```python
  from harlequelrah_py.files.myfiles import filereset
   filereset("file.txt")  # Efface le contenu de file.txt
  ```

  - **Paramètre :**
    - `file` (str) : Le chemin du fichier dont le contenu doit être effacé.
  - **Retourne :**
    - `None` : La fonction ne retourne rien.

  - **rline(file, line)** : Lit une ligne spécifique d'un fichier (le premier indice est 1).

  ```python
  from harlequelrah_py.files.myfiles import rline
  rline("file.txt", 3)  # Lit la 3ème ligne de file.txt
  ```

  - **Paramètre :**
    - `file` (str) : Le chemin du fichier à lire.
    - `line` (int) : Le numéro de la ligne à lire.
  - **Retourne :**
    - `None` : La fonction ne retourne rien.

  -**delfile(file, element)** : Efface toutes les lignes d'un fichier commençant par un élément en particulier.

  ```python
  from harlequelrah_py.files.myfiles import delfile
  delfile("file.txt", "#")  # Efface toutes les lignes de file.txt qui commencent par "#"
  ```

  - **Paramètre :**
    - `file` (str) : Le chemin du fichier à lire.
    - `element` (str) : L'élément par lequel les lignes à effacer commencent.
  - **Retourne :**
    - `None` : La fonction ne retourne rien.

- **repline(file, line, line_content)** : Remplace le contenu d'une ligne à une position précise.

```python
from harlequelrah_py.files.myfiles import repline
repline("file.txt", 1, "Nouvelle ligne 1")  # Remplace la 1ère ligne de file.txt par "Nouvelle ligne 1"
```

  - **Paramètre :**
    - `file` (str) : Le chemin du fichier à lire.
    - `line` (int) : Le numéro de la ligne à remplacer.
    - `line_content` (str) : Le nouveau contenu de la ligne.
  - **Retourne :**
    - `None` : La fonction ne retourne rien.

- **insline(file, line, line_content)** : Insère une ligne à une position précise.

```python
from harlequelrah_py.files.myfiles import insline
insline("file.txt", 2, "Ligne insérée")  # Insère "Ligne insérée" à la 2ème position de file.txt
```

  - **Paramètre :**
    - `file` (str) : Le chemin du fichier à lire.
    - `line` (int) : Le numéro de la ligne à inserer.
    - `line_content` (str) : Le nouveau contenu de la ligne.
  - **Retourne :**
    - `None` : La fonction ne retourne rien.

## Module `turtle`

#### Sous-module `geometric_shape`

Le sous-module `geometric_shape`  permet de dessiner des formes géométrique

 **figure** : Tracer une forme géométrique avec des couleurs différentes.

   Fonction : `figure(nbr_figure, rayon, nbr_cote=None, position=[], couleur=[], orientation=0)`

   Exemple d'utilisation :

   ```python
   from harlequelrah_py.geometric_shape import figure

   figure(
       nbr_figure=3,
       rayon=50,
       nbr_cote=4,
       position=[(0, 0), (100, 100), (200, 0)],
       couleur=["red", "blue", "green"],
       orientation=0
   )
   ```

   - **Paramètres** :
       - `nbr_figure` : `int` - Nombre de figures à tracer
       - `rayon` : `int` - Rayon de chaque figure
       - `nbr_cote` : `Optional[int]` - Nombre de côtés (None pour un cercle)
       - `position` : `List[Tuple[int, int]]` - Liste des positions de chaque figure
       - `couleur` : `List[str]` - Liste des couleurs pour chaque figure
       - `orientation` : `int` - Orientation initiale des figures
   - **Retour** : `None`

  **rectangle** : Dessiner un rectangle.

   Fonction : `rectangle(L, l, inside_color="white", line_color="black")`

   Exemple d'utilisation :

   ```python
   from harlequelrah_py.geometric_shape import rectangle

   rectangle(
       L=100,
       l=50,
       inside_color="yellow",
       line_color="black"
   )
   ```

   - **Paramètres** :
       - `L` : `int` - Longueur du rectangle
       - `l` : `int` - Largeur du rectangle
       - `inside_color` : `str` - Couleur de remplissage
       - `line_color` : `str` - Couleur du contour
   - **Retour** : `None`


#### Sous-module `particular_shape`
Le sous-module `particular_shape`  permet de dessiner des formes particulières

 **heart** : Dessiner un coeur

   Fonction : `heart(inside_color="white", line_color="black", background_color="white")`

   Exemple d'utilisation :

   ```python
   from harlequelrah_py.particular_shape import heart

   heart(
       inside_color="red",
       line_color="black",
       background_color="pink"
   )
   ```

   - **Paramètres** :
       - `inside_color` : `str` - Couleur de remplissage du cœur
       - `line_color` : `str` - Couleur du contour
       - `background_color` : `str` - Couleur de fond
   - **Retour** : `None`

## Module `string`
#### Sous-Module `mychar`
Le sous-module `mychar`  permet de faire des opérations spécifiques sur les chaines de caractère

**voy** :  verifie si le caractère est une voyelle et en renvoie un boolean

```python
   from harlequelrah_py.string.mychar import voy
   voy('a') # Renvoie True
   voy('b') # Renvoie False
```
  - **Paramètre** :
    - `x` (`string`) : le caractère à verifier.
  -  **Retourne** :
    - `boolean` : `True` si x est une voyelle et `False` sinon.

**nbr_voy** :Renvoie le nombre de voyelles dans une chaîne de caractères.

```python
from harlequelrah_py.string.mychar import nbr_voy
nbr_voy("example") # Renvoie 3 (pour 'e', 'a' et 'e')
```
  - **Paramètre** :
    - `y` (`string`) :  La chaîne de caractères à analyser.
  -  **Retourne** :
    - `int` : Le nombre de voyelles présentes dans y.

**inter_char** : Vérifie si un caractère donné est compris entre deux autres caractères (selon l'ordre ASCII).

```python
from harlequelrah_py.string.mychar import inter_char
inter_char('m', 'a', 'z') # Renvoie True
inter_char('A', 'a', 'z') # Renvoie False
```
  - **Paramètre** :
    - `char` (`string`)  : Le caractère à verifier.
    - `char_1` (`string`) : La borne inférieure.
    - `char_2` (`string`) : La borne supérieure.
  -  **Retourne** :
    - `boolean` : `True` si `char` est entre `char_1` et `char_2`, `False` sinon.

**minusmaj** : Détecte si un caractère est en minuscule, en majuscule, ou aucun des deux.

```python
from harlequelrah_py.string.mychar import minusmaj
minusmaj('a') # Renvoie True
minusmaj('A') # Renvoie False
minusmaj('1') # Renvoie None
```
  - **Paramètre** :
    - `char` (`string`)  : Le caractère à verifier.
  -  **Retourne** :
    - `boolean` : `True` si `char` est entre minuscule , `False` si char est en majuscule et `None` sinon aucun des deux.

#### Sous-Module `mysequence`
Le sous-module `mysequence`  permet de faire des opérations spécifiques sur les chaines de caractère

**all_index** : Renvoie une liste contenant les indices de toutes les occurrences d’un élément dans une chaîne de caractères ou une liste.

```python
from harlequelrah_py.string.mysequence import all_index
all_index("banana", "a") # Renvoie [1, 3, 5]
```
  - **Paramètre** :
    - `char` (`string` ou `list`) : La chaîne de caractères ou la liste dans laquelle chercher.
    - `element` (`string` ou `int`) : L' élément à rechercher .
  -  **Retourne** :
    - `list` : Une liste d’indices où element apparaît dans phrase_1.

**supp_all** : Supprime toutes les occurrences d’un élément donné dans une liste ou une chaîne de caractères.

```python
  from harlequelrah_py.string.mysequence import supp_all
  supp_all([1, 2, 3, 2, 4], 2) # Renvoie [1, 3, 4]
```
  - **Paramètre** :
    - `char` (`string` ou `list`) : La liste ou chaîne à modifier.
    - `element` (`string` ou `int`) : L' élément à rechercher .
  -  **Retourne** :
    - `list` : La liste ou chaîne de caractères sans les occurrences de element.

**ispalindrome**: Vérifie si une chaîne ou une liste est un palindrome.

```python
from harlequelrah_py.string.mysequence import pal
pal("radar") # Renvoie True
pal("hello") # Renvoie False
```
  - **Paramètre** :
    - `seq` (`string` ou `list`) : La liste ou chaîne à verifier.
  -  **Retourne** :
    - `boolean` : `True` si `seq` est un palindrome, `False` sinon.

**nbr_element** :Renvoie le nombre de chaque occurrences de chaque element dans une chaîne de caractères ou une liste.

```python
from harlequelrah_py.string.mysequence import nbr_let
nbr_element("hello") # Renvoie {'h': 1, 'e': 1, 'l': 2, 'o': 1}
nbr_element("hello", "l") # Renvoie 2
nbr_element([1, 2, 1, 4, 5, 6, 7, 6, 9, 2, 7]) # Renvoie {1: 2, 2: 2, 4: 1, 5: 1, 6: 2, 7: 2, 9: 1}

```
  - **Paramètre** :
    - `seq` (`string` ou `list`) : La  chaîne à analyser.
  -  **Retourne** :
    - `dict` `int` : Un dictionnaire avec chaque element et son nombre d’occurrences, ou un entier représentant le nombre d’occurrences de x.

**show_casse** :Analyse les caractères en majuscule et minuscule dans une chaîne ou une liste et retourne des listes spécifiques en fonction du paramètre casse.

```python
from harlequelrah_py.string.mysequence import casse
casse("Hello World") # Renvoie (['e', 'l', 'o'], ['H', 'W'])
casse("Hello World", 0) # Renvoie ['e', 'l', 'o']
casse("Hello World", 1) # Renvoie ['H', 'W']
casse("Hello World", -1) # Renvoie [3, 2]
```
  - **Paramètre** :
    - char_liste (string ou list) : La chaîne ou liste de caractères à analyser.
    - show_casse (int, optionnel) :
      - Si None, renvoie une liste des minuscules et une liste des majuscules.
      - Si 0, renvoie uniquement les minuscules.
      - Si 1, renvoie uniquement les majuscules.
      - Si -1, renvoie le nombre de minuscules et de majuscules.
  -  **Retourne** :
    - `tuple` ou `list` : Les listes de minuscules et de majuscules, ou des décomptes en fonction du paramètre casse.

#### Sous-Module `mycryptography`
Le sous-module `mycryptography`  permet de faire des opérations spécifiques sur le codage par cryptographie.

**cesar** : Encode ou décode un mot en utilisant le chiffrement de César avec une clé de décalage spécifiée.
```python
from harlequelrah_py.string.mycryptography import cesar
cesar("Bonjour", operation=1, k=3) # Encode le mot et renvoie Erqmrxu
cesar("Erqmrxu", operation=-1, k=3) # Decode le mot et renvoie Bonjour
```
  - **Paramètres** :
    - mot (`string`) : Le mot à coder ou décoder.
    - operation (`int`) : 1 pour coder, -1 pour décoder.
    - k (`int`) : La clé de décalage pour le chiffrement (par défaut 3).
  - **Retourne** :
    - `string` : Le mot codé ou décodé selon le chiffrement de César.

**verif_cesar** : Décrypte un mot codé en utilisant le chiffrement de César et renvoie un dictionnaire des possibilités en fonction de chaque décalage possible.
```python
from harlequelrah_py.string.mycryptography import verif_cesar
verif_cesar("Erqmrxu") # Renvoie toutes les possibilités de décodage ex : {'Erqmrxu': 0, 'Dqplqwt': 1, 'Cpokpvs': 2, 'Bonjour': 3,...}
```
  - **Paramètres** :
    - mot (`string`) : Le mot à déchiffrer.
  - **Retourne** :
    - `dict` : Un dictionnaire où chaque clé est une possibilité de mot clair et la valeur correspond au décalage.

**z_cesar** : Décrypte une phrase ou une chaîne codée en utilisant le chiffrement de César, en renvoyant un dictionnaire des décryptages possibles pour chaque mot de la chaîne.
```python
from harlequelrah_py.string.mycryptography import z_cesar
z_cesar("Erqmrxu Phz") # Renvoie un dictionnaire des possibilités de mots clairs pour chaque mot de la chaîne ex :{0: 'Erqmrxu Phz', 1: 'Dqplqwt Ogy', 2: 'Cpokpvs Nfx', 3: 'Bonjour Mew'....}
```
  - **Paramètres** :
    - chaine (`string`) :  La chaîne de caractères codée à analyser
  - **Retourne** :
    - `dict` :  Un dictionnaire où chaque clé est un décalage et chaque valeur est la chaîne possible pour ce décalage.

## Module `types`

Ce module comporte des classes utilisées comme types ou structure de données

### Sous Module `landmark`
Ce sous module comporte les classes  LandMark et Point

**`Point`**

- `__init__`:

  - **paramètres** :

    - x : **int**  représente l'abscisse

    - y : **int** représente l'ordonnée


**`LandMark`** :

- `__init__` :

  - **paramètres** :

    - type_land_mark: **type** , default Any

- land_marks: **dict[Point,type_land_mark:type]**

- `get_point` : retourne le point dans le repere à partir de ces coordonnées

  - **paramètres**  :

    - point : **Point**

- `set_point` : change un point et sa valeur

  - **paramètres**  :

    - point : **Point**

    - obj : **type_land_mark**


- `add_point` : ajoute un point et sa valeur

  - **paramètres**  :

    - point : **Point**

    - obj : **type_land_mark**

- `is_valid_obj` : verifie si un objet est valide du type **type_land_mark**

  - **paramètres**  :

    - obj : **type_land_mark**

  - **sortie** : **bool** -

- `exist_point` : verifie si un point existe

  - **paramètres**  :

    - point : **Point**

  - **sortie** : **bool**


- `remove_point` : retire un point du repère

  - **paramètres**  :

    - point : **Point**

- `list_marks` : liste les coordonnées et leurs valeurs

- `land_marks` **@property**

`ex` :

```python
my_land = LandMark()
my_land.add_point(Point(2,5),55)
my_land.list_marks()
my_land.set_point(Point(2,5),"mdr")
my_land.list_marks()
my_land.remove_point(Point(2,5))
my_land.list_marks()


new_land = LandMark(type_land_mark=int)
new_land.add_point(Point(1,2),2)
new_land.add_point(Point(2,3),3)
new_land.list_marks()
new_land.add_point(Point(1,2),"hi") # Provoque une erreur
```



## Contact ou Support
Pour des questions ou du support, contactez-moi à maximeatsoudegbovi@gmail.com ou au (+228) 91 36 10 29.






