ESP8266 타임스탬프를 사용하여 SD 카드에 데이터 기록

이 튜토리얼은 ESP8266을 사용하여 마이크로 SD 카드에 타임스탬프를 포함한 데이터를 로깅하는 방법에 대한 종합적인 지침을 제공합니다. 다루는 주요 구성 요소는 다음과 같습니다:

타임스탬프는 RTC 모듈에서 획득되며, 해당 데이터와 함께 마이크로 SD 카드에 저장됩니다. 마이크로 SD 카드에 저장된 정보는 다양할 수 있으며, 어떤 센서의 읽기 또는 출입문 잠금 접근의 로그에 해당될 수 있습니다...

이 과정을 설명하기 위해 이 튜토리얼은 두 개의 아날로그 핀에서 읽은 값을 활용합니다. 그러나 제공된 코드는 다양한 유형의 데이터를 수용할 수 있도록 쉽게 조정할 수 있습니다.

ESP8266 NodeMCU Log to Micro SD Card

준비물

1×ESP8266 NodeMCU Amazon
1×USB Cable Type-C 쿠팡 | Amazon
1×Micro SD Card Amazon
1×Micro SD Card Module 쿠팡 | Amazon
1×(Optional) MicroSD to SD Memory Card Adapter Amazon
1×Real-Time Clock DS3231 Module Amazon
1×CR2032 battery Amazon
1×Jumper Wires Amazon
1×(추천) 5V Power Adapter for ESP8266 Amazon
1×(추천) Screw Terminal Expansion Board for ESP8266 쿠팡 | Amazon
1×(추천) Power Splitter For ESP8266 Type-C Amazon
공개: 이 섹션에서 제공된 링크 중 일부는 제휴 링크입니다. 이 링크를 통해 구매한 경우 추가 비용없이 수수료를 받을 수 있습니다. 지원해 주셔서 감사합니다.

마이크로 SD 카드 모듈과 RTC 모듈에 대하여

Micro SD Card Module과 RTC 모듈(핀배열, 작동 방식 및 프로그래밍 방법 포함)에 익숙하지 않으시다면, 다음 튜토리얼을 참고해 주세요:

선연결

ESP8266 NodeMCU Micro SD Card Module wiring diagram

이 이미지는 Fritzing을 사용하여 만들어졌습니다. 이미지를 확대하려면 클릭하세요.

ESP8266 핀배열ESP8266 전원 공급 방법에 대해 더 많이 보십시오.

※ Note:

이더넷 쉴드나 마이크로 SD 카드 홀더가 있는 다른 쉴드를 사용하는 경우, 마이크로 SD 카드 모듈을 사용할 필요가 없습니다. 쉴드에 있는 마이크로 SD 카드 홀더에 마이크로 SD 카드를 삽입하기만 하면 됩니다.

ESP8266 - 타임스탬프와 함께 마이크로 SD 카드에 데이터 기록하기

/* * 이 ESP8266 NodeMCU 코드는 newbiely.kr 에서 개발되었습니다 * 이 ESP8266 NodeMCU 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/esp8266/esp8266-log-data-with-timestamp-to-sd-card */ #include <SD.h> #include <RTClib.h> #define PIN_SPI_CS D8 #define FILE_NAME "log.txt" RTC_DS3231 rtc; File myFile; void setup() { Serial.begin(9600); // RTC 모듈 설정 if (!rtc.begin()) { Serial.println(F("Couldn't find RTC")); while (1); } if (!SD.begin(PIN_SPI_CS)) { Serial.println(F("SD CARD FAILED, OR NOT PRESENT!")); while (1); // 더 이상 아무 것도 하지 않음: } Serial.println(F("SD CARD INITIALIZED.")); Serial.println(F("--------------------")); } void loop() { // 쓰기를 위한 파일 오픈 myFile = SD.open(FILE_NAME, FILE_WRITE); if (myFile) { Serial.println(F("Writing log to SD Card")); // 타임스탬프 쓰기 DateTime now = rtc.now(); myFile.print(now.year(), DEC); myFile.print('-'); myFile.print(now.month(), DEC); myFile.print('-'); myFile.print(now.day(), DEC); myFile.print(' '); myFile.print(now.hour(), DEC); myFile.print(':'); myFile.print(now.minute(), DEC); myFile.print(':'); myFile.print(now.second(), DEC); myFile.print(" "); // 타임스탬프와 데이터 사이 구분자 // 데이터 읽기 int analog_1 = analogRead(A0); int analog_2 = analogRead(A1); // 데이터 쓰기 myFile.print("analog_1 = "); myFile.print(analog_1); myFile.print(", "); // 데이터 사이 구분자 myFile.print("analog_2 = "); myFile.print(analog_2); myFile.write("\n"); // 새 줄 myFile.close(); } else { Serial.print(F("SD Card: error on opening file ")); Serial.println(FILE_NAME); } delay(2000); // 2초 지연 }

사용 방법

Arduino IDE에서 ESP8266을 시작하는 방법을 알아보려면 다음 단계를 따르세요:

  • ESP8266을 처음 사용하시는 경우, ESP8266 - 소프트웨어 설치 튜토리얼을 확인하세요.
  • 도면에 표시된 대로 구성 요소를 연결하세요.
  • USB 케이블을 사용하여 ESP8266 보드를 컴퓨터에 연결하세요.
  • 컴퓨터에서 Arduino IDE를 엽니다.
  • 정확한 ESP8266 보드를 선택하세요. 예를 들어, NodeMCU 1.0 (ESP-12E Module)과 해당 COM 포트를 선택하세요.
  • Micro SD 카드가 FAT16 또는 FAT32로 포맷되었는지 확인하세요(이에 대한 자세한 정보는 온라인에서 찾을 수 있습니다).
  • 코드를 복사하고 Arduino IDE에서 엽니다.
  • Arduino IDE에서 Upload 버튼을 클릭하여 코드를 컴파일하고 ESP8266에 업로드하세요.
  • 마지막으로, 시리얼 모니터에서 결과를 확인하세요.
COM6
Send
SD CARD INITIALIZED. -------------------- Writing log to SD Card Writing log to SD Card Writing log to SD Card Writing log to SD Card Writing log to SD Card Writing log to SD Card Writing log to SD Card
Autoscroll Show timestamp
Clear output
9600 baud  
Newline  
  • Micro SD 카드 모듈에서 Micro SD 카드를 제거하십시오.
  • Micro SD 카드를 USB SD 카드 리더기에 삽입하십시오.
  • USB SD 카드 리더기를 PC에 연결하십시오.
  • PC에서 log.txt 파일을 열면 다음과 같이 표시됩니다.
ESP8266 NodeMCU log to Micro SD Card with time information

USB SD 카드 리더기가 없는 경우, 아래의 ESP8266 코드를 실행하여 로그 파일의 내용을 확인할 수 있습니다.

/* * 이 ESP8266 NodeMCU 코드는 newbiely.kr 에서 개발되었습니다 * 이 ESP8266 NodeMCU 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/esp8266/esp8266-log-data-with-timestamp-to-sd-card */ #include <SD.h> #define PIN_SPI_CS D8 #define FILE_NAME "log.txt" File myFile; void setup() { Serial.begin(9600); if (!SD.begin(PIN_SPI_CS)) { Serial.println(F("SD CARD FAILED, OR NOT PRESENT!")); while (1); // 더 이상 아무것도 하지 마십시오: } Serial.println(F("SD CARD INITIALIZED.")); // 파일을 읽기 위해 열기 myFile = SD.open(FILE_NAME, FILE_READ); if (myFile) { while (myFile.available()) { char ch = myFile.read(); // Micro SD 카드에서 한 번에 하나의 문자를 읽습니다 Serial.print(ch); // 문자를 시리얼 모니터에 출력합니다 } myFile.close(); } else { Serial.print(F("SD Card: 파일을 여는 중 오류 ")); Serial.println(FILE_NAME); } } void loop() { }

ESP8266 - 여러 파일에 데이터 로그하기

단일 파일에 로깅을 하면 시간이 지남에 따라 파일 크기가 커져서 검토하기 어려울 수 있습니다. 아래의 코드는 YYYYMMDD.txt 형식으로 날짜 정보가 포함된 파일 이름을 가진, 날짜별로 하나씩 여러 파일을 생성할 것입니다.

/* * 이 ESP8266 NodeMCU 코드는 newbiely.kr 에서 개발되었습니다 * 이 ESP8266 NodeMCU 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/esp8266/esp8266-log-data-with-timestamp-to-sd-card */ #include <SD.h> #include <RTClib.h> #define PIN_SPI_CS D8 RTC_DS3231 rtc; File myFile; char filename[] = "yyyymmdd.txt"; // 파일명(확장자 제외)은 8자를 넘지 않아야 함 void setup() { Serial.begin(9600); // RTC 모듈 설정 if (!rtc.begin()) { Serial.println(F("RTC를 찾을 수 없습니다")); while (1); } if (!SD.begin(PIN_SPI_CS)) { Serial.println(F("SD 카드 실패, 또는 없음!")); while (1); // 더 이상 아무 것도 실행하지 않음: } Serial.println(F("SD 카드 초기화.")); Serial.println(F("--------------------")); } void loop() { DateTime now = rtc.now(); int year = now.year(); int month = now.month(); int day = now.day(); // 파일명 업데이트 filename[0] = (year / 1000) + '0'; filename[1] = ((year % 1000) / 100) + '0'; filename[2] = ((year % 100) / 10) + '0'; filename[3] = (year % 10) + '0'; filename[4] = (month / 10) + '0'; filename[5] = (month % 10) + '0'; filename[6] = (day / 10) + '0'; filename[7] = (day % 10) + '0'; // 쓰기를 위해 파일 열기 myFile = SD.open(filename, FILE_WRITE); if (myFile) { Serial.println(F("SD 카드에 로그 쓰기")); // 타임스탬프 쓰기 myFile.print(now.year(), DEC); myFile.print('-'); myFile.print(now.month(), DEC); myFile.print('-'); myFile.print(now.day(), DEC); myFile.print(' '); myFile.print(now.hour(), DEC); myFile.print(':'); myFile.print(now.minute(), DEC); myFile.print(':'); myFile.print(now.second(), DEC); myFile.print(" "); // 타임스탬프와 데이터 사이 구분자 // 데이터 읽기 int analog_1 = analogRead(A0); int analog_2 = analogRead(A1); // 데이터 쓰기 myFile.print("analog_1 = "); myFile.print(analog_1); myFile.print(", "); // 데이터 사이 구분자 myFile.print("analog_2 = "); myFile.print(analog_2); myFile.write("\n"); // 새로운 줄 myFile.close(); } else { Serial.print(F("SD 카드: 파일 열기 오류 ")); Serial.println(filename); } delay(2000); // 2초 지연 }

길고 긴 런을 완료한 후, 만약 여러분이:

  • 마이크로 SD 카드를 마이크로 SD 카드 모듈에서 제거하십시오
  • 마이크로 SD 카드를 USB SD 카드 리더기에 넣으십시오
  • USB SD 카드 리더기를 PC에 연결하십시오
  • 다음과 같이 파일을 볼 수 있습니다:
ESP8266 NodeMCU log to Micro SD Card multiple files

동영상

비디오 제작은 시간이 많이 걸리는 작업입니다. 비디오 튜토리얼이 학습에 도움이 되었다면, YouTube 채널 을 구독하여 알려 주시기 바랍니다. 비디오에 대한 높은 수요가 있다면, 비디오를 만들기 위해 노력하겠습니다.