Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentesRévision précédente
Prochaine révision
Révision précédente
documentation:architecture-technique:captation-des-donnees [2023/04/03 12:36] baudryjdocumentation:architecture-technique:captation-des-donnees [2023/04/03 12:47] (Version actuelle) – [Captation des données] baudryj
Ligne 1: Ligne 1:
 ====== Captation des données ====== ====== Captation des données ======
 +
 +  * Sensor port série
 +
 +<code python>
 +import serial
 +import datetime
 +import os
 +import time
 +
 +# Configuration du port série
 +port = "/dev/ttyUSB0"
 +baudrate = 9600
 +timeout = 1
 +
 +# Ouvre la connexion au port série
 +try:
 +    ser = serial.Serial(port, baudrate, timeout=timeout)
 +except serial.SerialException as e:
 +    print(f"Impossible d'ouvrir le port série {port}: {e}")
 +    exit(1)
 +
 +# Boucle principale
 +while True:
 +    try:
 +        # Lecture des données du port série
 +        data = ser.readline().decode('utf-8').strip()
 +
 +        # Si des données ont été reçues
 +        if data:
 +            # Obtention de la date et l'heure actuelles
 +            now = datetime.datetime.now()
 +            date_string = now.strftime("%Y-%m-%d")
 +            time_string = now.strftime("%H-%M-%S")
 +
 +            # Nom du fichier avec la date et l'heure actuelles
 +            file_name = f"{date_string}_{time_string}.txt"
 +
 +            # Vérifier si le dossier de destination existe, sinon le créer
 +            if not os.path.exists("/path/to/destination/folder"):
 +                os.makedirs("/path/to/destination/folder")
 +
 +            # Ouverture du fichier en mode écriture
 +            with open(f"/path/to/destination/folder/{file_name}", 'a') as file:
 +                # Écriture des données dans le fichier
 +                file.write(data + '\n')
 +
 +        # Attendre 1 seconde avant la prochaine lecture
 +        time.sleep(1)
 +
 +    except serial.SerialException as e:
 +        print(f"Erreur de lecture du port série {port}: {e}")
 +        ser.close()
 +        exit(1)
 +
 +    except IOError as e:
 +        print(f"Erreur d'entrée/sortie sur le port série {port}: {e}")
 +        ser.close()
 +        exit(1)
 +
 +    except Exception as e:
 +        print(f"Erreur non gérée: {e}")
 +        ser.close()
 +        exit(1)
 +
 +</code>
  
   * Pour détecter si le port série ne reçoit plus de données pendant 20 secondes, vous pouvez utiliser un minuteur (timer) dans votre code Python. Voici un exemple de code qui utilise la bibliothèque time pour mesurer le temps écoulé depuis la dernière réception de données, et qui déclenche une action si ce temps dépasse 20 secondes :   * Pour détecter si le port série ne reçoit plus de données pendant 20 secondes, vous pouvez utiliser un minuteur (timer) dans votre code Python. Voici un exemple de code qui utilise la bibliothèque time pour mesurer le temps écoulé depuis la dernière réception de données, et qui déclenche une action si ce temps dépasse 20 secondes :
Ligne 38: Ligne 103:
  
 </code> </code>
 +
 +<code python>
 +import requests
 +import serial
 +import time
 +
 +# Configuration du port série
 +port = "/dev/ttyUSB0"
 +baudrate = 9600
 +timeout = 1
 +
 +# Configuration du webhook
 +webhook_url = "https://example.com/webhook"
 +webhook_timeout = 3
 +
 +# Ouvre la connexion au port série
 +try:
 +    ser = serial.Serial(port, baudrate, timeout=timeout)
 +except serial.SerialException as e:
 +    print(f"Impossible d'ouvrir le port série {port}: {e}")
 +    exit(1)
 +
 +# Boucle principale
 +while True:
 +    try:
 +        # Lecture des données du port série
 +        data = ser.readline().decode('utf-8').strip()
 +
 +        # Faire quelque chose avec les données
 +
 +        # Envoyer les données au webhook
 +        payload = {"data": data}
 +        response = requests.post(webhook_url, json=payload, timeout=webhook_timeout)
 +        response.raise_for_status()
 +
 +    except requests.exceptions.Timeout:
 +        print(f"Timeout lors de l'envoi des données au webhook {webhook_url}")
 +    except requests.exceptions.RequestException as e:
 +        print(f"Erreur lors de l'envoi des données au webhook {webhook_url}: {e}")
 +
 +    # Attendre 5 secondes avant de continuer
 +    time.sleep(5)
 +</code>
 +===== Création d'un fichier de log =====
 +
 +<code python>
 +import serial
 +import logging
 +
 +# Configuration du port série
 +port = "/dev/ttyUSB0"
 +baudrate = 9600
 +timeout = 1
 +
 +# Configuration du logger
 +logging.basicConfig(filename='myapp.log', level=logging.ERROR)
 +
 +# Ouvre la connexion au port série
 +try:
 +    ser = serial.Serial(port, baudrate, timeout=timeout)
 +except serial.SerialException as e:
 +    logging.error(f"Impossible d'ouvrir le port série {port}: {e}")
 +    exit(1)
 +
 +# Boucle principale
 +while True:
 +    try:
 +        # Lecture des données du port série
 +        data = ser.readline().decode('utf-8').strip()
 +
 +        # Faire quelque chose avec les données
 +
 +    except serial.SerialException as e:
 +        logging.error(f"Erreur de lecture du port série {port}: {e}")
 +        exit(1)
 +</code>
 +
Haut de page