python soket sendTo pd netreveive

This commit is contained in:
bach 2025-03-27 22:41:12 +01:00
parent 973e5ae657
commit cf4e506523
4 changed files with 50 additions and 16 deletions

View File

@ -10,3 +10,5 @@ pip install uv
uv sync
./main.py
```
![](maregraphe_pd.png)

56
main.py Normal file → Executable file
View File

@ -1,11 +1,21 @@
#!/usr/bin/env python
import requests
import time
import logging
import socket
import json
import subprocess
# Configuration de l'API REFMAR
API_URL = "https://services.data.shom.fr/refmar/v1.0/GetTideData"
API_KEY = "votre_cle_api" # Remplacez par votre clé API
STATION = "LEHAVRE" # Identifiant de la station du Havre
API_URL = "https://services.data.shom.fr/maregraphie/service/completetidegauge"
# API_KEY = "votre_cle_api" # Remplacez par votre clé API
STATION = '386' # Identifiant de la station du Havre
UDP_IP = "127.0.0.1"
UDP_PORT = 8765
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
# Configuration du logging
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
@ -13,14 +23,14 @@ logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(
def fetch_data():
"""Récupère les données du marégraphe via l'API REFMAR."""
headers = {
"Ocp-Apim-Subscription-Key": API_KEY,
# "Ocp-Apim-Subscription-Key": API_KEY,
}
params = {
"station": STATION,
"time": "current", # Vous pouvez ajuster ce paramètre selon vos besoins
# "station": STATION,
# "time": "current", # Vous pouvez ajuster ce paramètre selon vos besoins
}
try:
response = requests.get(API_URL, headers=headers, params=params)
response = requests.get(API_URL+"/"+STATION, headers=headers, params=params)
response.raise_for_status()
return response.json()
except requests.RequestException as e:
@ -30,21 +40,35 @@ def fetch_data():
def process_data(data):
"""Traite les données récupérées."""
try:
# Exemple de traitement des données
tide_height = data.get("height", 0)
logging.info(f"Hauteur de la marée : {tide_height} mètres")
# Ajoutez ici le traitement spécifique que vous souhaitez effectuer avec les données
zh_ref = data.get("verticalRef", {}).get("zh_ref", 0)
logging.info(f"Hauteur de la marée : {zh_ref} mètres")
zh_ref_bytes = f"{zh_ref};".encode('utf-8')
sock.sendto(zh_ref_bytes, (UDP_IP, UDP_PORT))
# sock.sendto(float(zh_ref).to_bytes(8, byteorder='big'), (UDP_IP, UDP_PORT))
# sock.sendto(float(zh_ref), (UDP_IP, UDP_PORT))
except Exception as e:
logging.error(f"Erreur lors du traitement des données : {e}")
def main():
"""Fonction principale qui exécute la boucle de récupération et de traitement des données."""
logging.info("Démarrage de l'application de traitement des données du marégraphe.")
while True:
data = fetch_data()
if data:
process_data(data)
time.sleep(300) # Attendre 5 minutes
# lancement du patch pd
pd_patch = "./maregraphe.pd" # Remplace par le chemin de ton patch
pd_process = subprocess.Popen(["pd", "-nogui", "-open", pd_patch])
try:
while True:
data = fetch_data()
logging.info(json.dumps(data, indent=2))
# print(data)
if data:
process_data(data)
time.sleep(10) # 300 Attendre 5 minutes
except KeyboardInterrupt:
print("Arrêt du script, fermeture de Pure Data...")
pd_process.terminate()
if __name__ == "__main__":
main()

8
maregraphe.pd Normal file
View File

@ -0,0 +1,8 @@
#N canvas 960 30 952 485 12;
#X obj 118 116 float;
#X obj 67 116 print;
#X obj 118 59 netreceive -u -b 8765;
#X obj 118 89 list tosymbol;
#X connect 0 0 1 0;
#X connect 2 0 3 0;
#X connect 3 0 0 0;

BIN
maregraphe_pd.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB