IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Arduino Discussion :

Ecrire dans un fichier SPIFFS [Arduino ESP32]


Sujet :

Arduino

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Inscrit en
    Juillet 2004
    Messages
    967
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 967
    Par défaut Ecrire dans un fichier SPIFFS
    Bonjour à tous,

    Un petit coup de main me serait utile car je n'arrive pas à inscrire dans mon "histo.txt" mes données
    pourtant le croquis fonctionne et signale l’écriture comme normale
    j'ai du oublier quelque chose
    je joins le croquis :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
     
    #include <WiFi.h>
    #include <HTTPClient.h>
    #include <ArduinoJson.h>
    #include <Wire.h>
    #include <Adafruit_GFX.h>
    #include <Adafruit_SSD1306.h>
    #include <time.h>
     
    #include "FS.h"
    #include "SPIFFS.h"
     
    // OLED
    #define SCREEN_WIDTH 128
    #define SCREEN_HEIGHT 64
    #define SCREEN_ADDRESS 0x3C ///< See datasheet for Address; 0x3D for 128x64, 0x3C for 128x32
    Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, -1);
     
     
    // Wi-Fi
    const char* ssid = "xxxxxx";
    const char* password = "xxxxxxx";
     
    // Coordonnées GPS
    const float latitude = 45.658952;
    const float longitude = 5.27877;
     
    // Fuseau horaire local (ex: Paris = UTC+2 en été)
    const long gmtOffset_sec = 2* 3600; // <====
    const int daylightOffset_sec = 0;
     
    // NTP
    const char* ntpServer = "pool.ntp.org"; // <====
     
    String sunriseLocal, sunsetLocal, dateStr;
    int dernierJour = -1;
     
    void setup() {
      Serial.begin(115200);
      if (!SPIFFS.begin(true)) {
      Serial.println("Erreur SPIFFS");
      }  
     
      // OLED
      if (!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) {
        Serial.println(F("Écran OLED non détecté"));
        while (true);
      }
     
      display.clearDisplay();
      display.setTextColor(SSD1306_WHITE);
      display.setTextSize(1);
      display.setCursor(0, 0);
      display.println("Connexion WiFi...");
      display.display();
     
      // Wi-Fi
      WiFi.begin(ssid, password);
      while (WiFi.status() != WL_CONNECTED) {
        delay(500);
      }
      Serial.println(WiFi.localIP());
     
      // NTP
      configTime(gmtOffset_sec, daylightOffset_sec, ntpServer);
     
      // Première récupération et affichage
      updateEph();
     
      // Attente pour éviter redémarrage rapide
      delay(2000);
    }
     
    void loop() {
      // Vérifie si un nouveau jour a commencé
      struct tm timeinfo;
      if (getLocalTime(&timeinfo)) {
        if (timeinfo.tm_mday != dernierJour) {
          updateEph();  // Nouveau jour → maj
        }
      }
     
      delay(60000);  // Vérifie toutes les minutes
    }
     
    void updateEph() {
      struct tm timeinfo;
      if (!getLocalTime(&timeinfo)) {
        Serial.println("Erreur temps local");
        return;
      }
     
      char dateBuf[20];
      strftime(dateBuf, sizeof(dateBuf),"%d-%m-%Y", &timeinfo);
      dateStr = String(dateBuf);
      dernierJour = timeinfo.tm_mday;
     
      getSunriseSunset(latitude, longitude);
      updateDisplay();
      saveToHistory(dateStr, sunriseLocal, sunsetLocal);
    }
     
    void getSunriseSunset(float lat, float lon) {
      HTTPClient http;
      String url = "https://api.sunrise-sunset.org/json?lat=" + String(lat, 6) + "&lng=" + String(lon, 6) + "&formatted=0";
      http.begin(url);
      int httpCode = http.GET();
     
      if (httpCode == 200) {
        String payload = http.getString();
        DynamicJsonDocument doc(2048);
        DeserializationError error = deserializeJson(doc, payload);
     
        if (!error) {
          String sunriseUTC = doc["results"]["sunrise"];
          String sunsetUTC = doc["results"]["sunset"];
          sunriseLocal = convertToLocal(sunriseUTC);
          sunsetLocal  = convertToLocal(sunsetUTC);
        }
      }
     
      http.end();
    }
     
    String convertToLocal(String iso8601) {
      struct tm t;
      int year, month, day, hour, minute, second;
      sscanf(iso8601.c_str(), "%d-%d-%dT%d:%d:%d", &year, &month, &day, &hour, &minute, &second);
     
      t.tm_year = year - 1900;
      t.tm_mon  = month - 1;
      t.tm_mday = day;
      t.tm_hour = hour;
      t.tm_min  = minute;
      t.tm_sec  = second;
      t.tm_isdst = -1;
     
      time_t utcTime = mktime(&t);  // UTC
      utcTime += gmtOffset_sec;     // Décalage vers local
     
      struct tm *local = localtime(&utcTime);
      char buf[6];
      sprintf(buf, "%02d:%02d", local->tm_hour, local->tm_min);
      return String(buf);
    }
     
    void updateDisplay() {
      display.clearDisplay();
      display.setCursor(0, 0);
      display.println("Eph. (heure locale)");
      display.println("Date : " + dateStr);
      display.println("Lever : " + sunriseLocal);
      display.println("Coucher: " + sunsetLocal);
      display.display();
     
      Serial.println("Affichage mis a jour");
    }
     
    void saveToHistory(String date, String sunrise, String sunset) {
      File file = SPIFFS.open("/histo.txt", FILE_APPEND);
      if (!file) {
        Serial.println("Erreur ouverture fichier histo.txt");
        return;
      }
      String line = date + " | Lever : " + sunrise + " | Coucher : " + sunset + "\n";
      file.print(line);
      file.close();
      Serial.println("Historique sauvegardé : " + line);
    }

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    14:25:54.556 -> 192.168.1.86
    14:25:59.638 -> Affichage mis a jour
    14:25:59.638 -> Historique sauvegardé : 16-07-2025 | Lever : 06:03 | Coucher : 21:26
    14:25:59.638 ->
    si quelqu'un a une idée ....
    merci mille fois

    pascal

  2. #2
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    13 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 13 197
    Billets dans le blog
    47
    Par défaut
    Salut,

    Un bug silencieux...

    Pour en avoir le cœur net, complète la ligne :
    avec le test :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if (file.print(line) == 0) Serial.println("J'ai rien écrit!!");
    Sinon, essaie en changeant de nom de fichier, le fichier .txt est peut-être corrompu et il refuse d'écrire dessus.

  3. #3
    Membre éprouvé
    Inscrit en
    Juillet 2004
    Messages
    967
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 967
    Par défaut
    Salut f-leb

    j'ai fait çà :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    void saveToHistory(String date, String sunrise, String sunset) {
      File file = SPIFFS.open("/histo.txt", "w");
      if (!file) {
        Serial.println("Erreur ouverture fichier histo.txt");
        return;
      }
      String line = date + " | Lever : " + sunrise + " | Coucher : " + sunset + "\n";
      file.print(line);
      if (file.print(line) == 0) Serial.println("J'ai rien écrit!!"); //<<======
      file.close();
      Serial.println("Historique sauvegardé : " + line);
     
      file = SPIFFS.open("/histo.txt", "r");
      Serial.print(file.readString());
      file.close();
     
    }
    et le résultat c'est çà :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    
    23:09:07.998 -> SPIFFS monté avec succès
    23:09:11.604 -> 192.168.1.86
    23:09:17.013 -> Affichage mis a jour
    23:09:17.013 -> Historique sauvegardé : 16-07-2025 | Lever : 06:03 | Coucher : 21:26
    23:09:17.013 -> 
    23:09:17.013 -> 16-07-2025 | Lever : 06:03 | Coucher : 21:26  ||
    23:09:17.013 -> 16-07-2025 | Lever : 06:03 | Coucher : 21:26  || lecture du fichier sur la console 
    mais on peut lire le fichier "histo.txt" directement sous Windows ( pour moi il est vide ) ou faut-il passer par le FTP ?

  4. #4
    Expert confirmé

    Homme Profil pro
    mad scientist :)
    Inscrit en
    Septembre 2019
    Messages
    2 908
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : mad scientist :)

    Informations forums :
    Inscription : Septembre 2019
    Messages : 2 908
    Par défaut
    Ou et comment essayez vous de lire le fichier ?

  5. #5
    Membre éprouvé
    Inscrit en
    Juillet 2004
    Messages
    967
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 967
    Par défaut
    Salut Jay M

    Ou et comment essayez vous de lire le fichier ?
    j'ai essayé de lire bêtement "histo.txt" sous windows directement
    j'avais créé ce fichier sous le répertoire "data"
    mais il est vide (?)

    comme j'ai créé un fichier appelé "histo.txt" sous SPIFFS alors je me suis dit que je ne pouvais le lire qu'avec çà à l'aide de la console :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
      file = SPIFFS.open("/histo.txt", "r");
      Serial.print(file.readString());
      file.close();
    et çà me donne ceci aujourd'hui avec la console :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     
    09:57:43.371 -> 192.168.1.86
    09:57:44.753 -> Affichage mis a jour
    09:57:44.801 -> Historique sauvegardé : 17-07-2025 | Lever : 06:04 | Coucher : 21:25
    09:57:44.801 -> 
    09:57:44.801 -> 17-07-2025 | Lever : 06:04 | Coucher : 21:25
    09:57:44.801 -> 17-07-2025 | Lever : 06:04 | Coucher : 21:25

  6. #6
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    13 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 13 197
    Billets dans le blog
    47
    Par défaut
    Il semble que ton opération d'écriture/lecture a fonctionné, non ?

    Mais je me demande s'il n'y a pas malentendu... Tu utilises le menu "ESP32 Sketch Data Upload" qu'il y avait dans l'EDI Arduino 1.x (parce qu'il ne fonctionne plus avec l'EDI 2.x il me semble).
    Et tu as mis un fichier "histo.txt" vide dans le sous-dossier Data que tu as flashé.

    Mais si ton fichier histo.txt du dossier Data reste désespérément vide après des opérations d'écriture, c'est tout à fait normal. Le dossier Data n'est pas un dossier monté comme une clé USB, c'est juste une zone temporaire pour créer un pseudo-système de fichiers dans la mémoire flash de l'ESP32 au moment de l'upload, mais l'ESP32 n'a pas accès au système de fichiers Windows pour répercuter les modifications dans le dossier Data du PC.

    Il s'agirait donc d'un malentendu sur l'emplacement du fichier. Le fichier que tu modifies dynamiquement dans ton sketch est stocké dans une zone de mémoire Flash de l'ESP32, et ce n'est pas le même que celui dans ton dossier Data sous Windows.

  7. #7
    Expert confirmé

    Homme Profil pro
    mad scientist :)
    Inscrit en
    Septembre 2019
    Messages
    2 908
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : mad scientist :)

    Informations forums :
    Inscription : Septembre 2019
    Messages : 2 908
    Par défaut
    Clairement un malentendu. Le fichier est stocké dans l’ESP32, il ne revient pas sur le PC.

  8. #8
    Membre éprouvé
    Inscrit en
    Juillet 2004
    Messages
    967
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 967
    Par défaut
    Bonjour à tous ,

    Effectivement, j'avais prévenu , j'avais dit : "bêtement"
    alors ma question est :
    comment fait-on pour lire ce fichier dynamiquement , seule la voie FTP est nécessaire ?

  9. #9
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    13 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 13 197
    Billets dans le blog
    47
    Par défaut
    Citation Envoyé par cobra38 Voir le message
    comment fait-on pour lire ce fichier dynamiquement , seule la voie FTP est nécessaire ?
    Tu peux, mais il faut configurer l'esp32 en serveur FTP (chercher une bibliothèque qui fait cela).
    Ce n'est pas le seul moyen. Si tu sers des pages Web avec ton esp32, tu peux mettre un lien de téléchargement, le client télécharge le fichier en cliquant sur le lien dans un navigateur.

    Sinon il y a plein de moyens pour transmettre des données texte, je pense en premier à la liaison série pour transmettre à coups de Serial.print()...

  10. #10
    Membre éprouvé
    Inscrit en
    Juillet 2004
    Messages
    967
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 967
    Par défaut
    Tu peux, mais il faut configurer l'esp32 en serveur FTP (chercher une bibliothèque qui fait cela).
    Ce n'est pas le seul moyen. Si tu sers des pages Web avec ton esp32, tu peux mettre un lien de téléchargement, le client télécharge le fichier en cliquant sur le lien dans un navigateur.

    Sinon il y a plein de moyens pour transmettre des données texte, je pense en premier à la liaison série pour transmettre à coups de Serial.print()...
    ok, merci f-leb je vais essayer çà .....

    merci à tous pour votre aide

    Bien cordialement
    pascal

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Ouvrir et écrire dans un fichier .txt en T-SQL
    Par joul's dans le forum MS SQL Server
    Réponses: 11
    Dernier message: 27/10/2008, 21h04
  2. Ecrire dans un fichier grace à un trigger ?
    Par zigoo dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 29/10/2004, 20h03
  3. [JAR] Comment écrire dans un fichier properties dans un jar
    Par Alec6 dans le forum Entrée/Sortie
    Réponses: 3
    Dernier message: 05/10/2004, 15h16
  4. Un langage pour lire, traiter et écrire de gros fichiers
    Par March' dans le forum Langages de programmation
    Réponses: 19
    Dernier message: 07/04/2003, 15h26
  5. Ecrire dans un fichier sans supprimer le reste
    Par koan_sabian dans le forum Linux
    Réponses: 4
    Dernier message: 20/02/2003, 15h44

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo