/ Arduino Data Logger (Log Temperature, Humidity, Time on SD Card and
Home Computer)
Arduino Data Logger (Log Temperature, Humidity, Time on SD Card and Computer)
By B.Aswinth Raj 9 Comments
Arduino Temperature Data Logger using DHT11
As Engineers/Developers we always rely upon the data collected to design or improve a system. Recording data and analyzing them is a
common practice in most of the industries, here we are building Arduino Data Logger Project where we will learn how we can log data at
a speci c interval of time. We will use an Arduino board to read some data (here temperature, humidity, date and time) and save them on
a SD card and the computer simultaneously.
AdChoices
Arduino Project
Code
The data saved can be easily opened in an Excel Sheet for further analyses. To maintain the date and time we will use the famous RTC
module DS3231 and to get the Temperature and Humidity we will use the DHT11 Sensor. At the end of the project you will learn
1. How to log data into SD card with Date, Time and sensor values.
2. How to write data directly to Excel Sheet on PC via serial communication.
Materials Required:
1. Breadboard
2. Arduino UNO (any Arduino board)
3. DHT11 Temperature sensor
4. DS3231 RTC module
5. SD card module
6. SD card
7. Connecting wires
8. Computer/Laptop
DHT11 Temperature and Humidity Sensor
Circuit Diagram:
The circuit Diagram for this Arduino Temperature Logger Project is shown below.
AdChoices
Download Spreadsheet
Reading Program
As shown in the circuit diagram the connections are very simple since we have used them as modules we can directly build them on a
breadboard. The connections are further classified in the table below
Arduino Pin Module Pin
Temperature Sensor – DHT11
Vcc 5V
Gnd Gnd
Nc Nc
Out Pin 7
RTC module DS3231
Vcc 5V
Gnd Gnd
SCL Pin A5
SDA Pin A4
SD card Module
Vcc 5V
Gnd Gnd
MISO Pin 12
MOSI Pin 11
SCK Pin 13
CS Pin 4
You can replace the DHT11 temperature sensor with any of your sensor from which you need to log the values. You can check LM35 with
Arduino to read temperature.
The RTC module DS3231 is interfaced with Arduino using the I2C communication (SCL, SDA) and the SD card module is interfaced using
the SPI Communication (MISO, MOSI, SCK, CS). The pins 4 and 7 are de ned as the CS pin and output pin by Arduino program, you can
change them to any other pin if required. We previously interfaced SD card with Arduino in Music player project.
Arduino Program Explanation:
We have to write the Arduino program which can do the following.
1. Read data from DTH11 Sensor (or any other data that you wish to log).
2. Initialize the I2C bus to read data from RTC module.
3. Initialize the SPI bus to interface the SD card module with Arduino.
4. Store the Date, Time, Temperature and Humidity into the SD card.
5. Store the Date, Time, Temperature and Humidity on a Excel Sheet running on a computer/Laptop.
The above steps might sound complicated but they are very easy since we have the libraries to do the hard job for us. You have to
download the following two libraries
1. DHT11 Sensor Library from GitHub
2. DS3231 RTC module library from Rinky-Dink Electronics
Once you have downloaded the library add them to your Arduino IDE by following
Sketch->Include Library -> Add .ZIP Library
To feed the data from Arduino lively into an Excel sheet on computer we will also need to install software called PLX-DAQ provided by
Parallax Inc. Follow the link to download the le and install them based on your operating system. This should have created a folder
named PLS-DAQ on your desktop. We will take care of it later in our working section.
Now after adding both libraries and after installing the software, you can use the Complete Code (given at bottom of tutorial) and upload
them to your Arduino. I have tried my best to keep the code as simple as possible and the explanations are also given through comment
sections. Further, I will explain the important segments below.
1. Reading Data from DS3231:
DS3231 is a RTC (Real Time Clock) module. It is used to maintain the date and time for most of the Electronics projects. This module has
its own coin cell power supply using which it maintains the date and time even when the main power is removed or the MCU has gone
though a hard reset. So once we set the date and time in this module it will keep track of it always.
Using this module is very easy because of the library provided by Arduino.
// Init the DS3231 using the hardware interface
DS3231 rtc(SDA, SCL);
void Initialize_RTC()
{
// Initialize the rtc object
rtc.begin();
//#### the following lines can be uncommented to set the date and time for the first time###
/*
rtc.setDOW(FRIDAY); // Set Day-of-Week to SUNDAY
rtc.setTime(18, 46, 45); // Set the time to 12:00:00 (24hr format)
rtc.setDate(6, 30, 2017); // Set the date to January 1st, 2014
*/
}
Note: When using this module for the rst time you have to set the date and time. It can be done by simply removing the comments as
mentioned above and writing the date and time. Make sure you comment them back and upload it, else each time you run the board the
date and time will be set again. You can also use RTC IC DS1307 for reading the time with Arduino .
2. Reading Data from DHT11:
DHT11 is a Temperature come Humidity sensor. It sends the values of temperature and humidity as an 8-bit data serially through the
output pin of the module. The library reads this data by using the software serial function of the Arduino.
#define DHT11_PIN 7 //Sensor output pin is connected to pin 7
dht DHT; //Sensor object named as DHT
void Read_DHT11()
{
int chk = DHT.read11(DHT11_PIN);
}
Here I have connected the output pin to pin 7 as example you can choose any pin that supports Software Serial. Calling DHT.read(pin
number); will read the value of temperature and humidity and store it in the parameter DHT.temperature and DHT.Humidity respectively.
Also check this DHT11 based Arduino Temperature Measurement.
3. Initializing the SC card module:
void Initialize_SDcard()
{
// see if the card is present and can be initialized:
if (!SD.begin(chipSelect)) {
Serial.println("Card failed, or not present");
// don't do anything more:
return;
}
// open the file. note that only one file can be open at a time,
// so you have to close this one before opening another.
File dataFile = SD.open("LoggerCD.txt", FILE_WRITE);
// if the file is available, write to it:
if (dataFile) {
dataFile.println("Date,Time,Temperature,Humidity"); //Write the first row of the excel file
dataFile.close();
}
}
Using an SD card with Arduino is easy because of the SD card library which will be added to the Arduino IDE by default. In the SD card
initialize function we will create a text le named “LoggerCD.txt” and write the rst row of our content. Here we separate the values by
using a “,” as a delimiter. Meaning when a comma is placed it means we have to move to the next cell in the Excel sheet.
4. Writing Data to SD card
void Write_SDcard()
{
// open the file. note that only one file can be open at a time,
// so you have to close this one before opening another.
File dataFile = SD.open("LoggerCD.txt", FILE_WRITE);
// if the file is available, write to it:
if (dataFile) {
dataFile.print(rtc.getDateStr()); //Store date on SD card
dataFile.print(","); //Move to next column using a ","
dataFile.print(rtc.getTimeStr()); //Store date on SD card
dataFile.print(","); //Move to next column using a ","
dataFile.print(DHT.temperature); //Store date on SD card
dataFile.print(","); //Move to next column using a ","
dataFile.print(DHT.humidity); //Store date on SD card
dataFile.print(","); //Move to next column using a ","
dataFile.println(); //End of Row move to next row
dataFile.close(); //Close the file
}
else
Serial.println("OOPS!! SD card writing failed");
}
As said earlier our intention is to save the Date, Time, Temperature and Humidity into our SD card . With the help of the DS3231 library
and the DHT11 library our Arduino will be capable of reading all these four parameters and storing them into the following parameters as
shown in table below
Date rtc.getDateStr());
Time rtc.getTimeStr());
Temperature DHT.temperature
Humidity DHT.humidity
Now we can directly use these parameters to store them on the SD card using the print line
dataFile.print(parameter);
You can notice that each parameter is separated by a comma to make it look legible and a dataFile.println(); is used to indicate the end of
the line.
5. Writing Data to PLX-DAQ
PLX-DAQ is Microsoft Excel Plug-in software that helps us to write values from Arduino to directly into an Excel le on our Laptop or PC.
This is my personal favourite because of two reasons:
1.You can write and monitor the data at the same time and provides us way to plot them as graphs.
2. You do not need a RTC Module like DS3231 to keep track of date and time. You can simply use the date and time running on your
Laptop/computer and save them directly on Excel.
To use this software with Arduino we have to send the data serially in a speci c pattern just like displaying value on serial monitor. The
key lines are explained below:
void Initialize_PlxDaq()
{
Serial.println("CLEARDATA"); //clears up any data left from previous projects
Serial.println("LABEL,Date,Time,Temperature,Humidity"); //always write LABEL, to indicate it as first line
}
void Write_PlxDaq()
{
Serial.print("DATA"); //always write "DATA" to Inidicate the following as Data
Serial.print(","); //Move to next column using a ","
Serial.print("DATE"); //Store date on Excel
Serial.print(","); //Move to next column using a ","
Serial.print("TIME"); //Store date on Excel
Serial.print(","); //Move to next column using a ","
Serial.print(DHT.temperature); //Store date on Excel
Serial.print(","); //Move to next column using a ","
Serial.print(DHT.humidity); //Store date on Excel
Serial.print(","); //Move to next column using a ","
Serial.println(); //End of Row move to next row
The software can recognize keywords like LABEL, DATA, TIME, DATE etc. As shown in the Initialize function the keyword “LABEL” is used
to write the rst ROW of the Excel sheet. Later in the Write function we use the keyword “DATA” to indicate that the following information
should be considered as DATA. To indicate that we have to move to next row we have to use comma (“,”). To indicate the end of row we
have to send a Serial.println();.
As said earlier we can write the system date and time by sending the keywords “DATE” and “TIME” respectively as shown above.
Note: Do not use serial monitor when using this PLX_DAQ software.
Working Explanation:
Working of the Arduino Data Logger is simple. Once the hardware and the software are ready it is time to burn the program into your
Arduino Board. As soon your program gets uploaded, your temperature and humidity values will start to get stored in your SD card. You
have to follow the steps below to enable PLX-DAQ to log the into Excel sheet in the computer.
Step 1: Open the “Plx-Daq Spreadsheet” file that was created on your desktop during installation.
Step 2: If there is a Security block, click on Options->Enable the content -> Finish -> OK to get the following screen.
Step 3: Now select the baud rate as “9600” and the port to which your Arduino is connected and click on Connect. Your values should
start to get logged like shown in the picture below.
You can leave this excel sheet open and monitor the values as they get logged. As this is happening our SD card would also have saved
the same values. To check is that is working simply remove the SD card and open it on your Computer. You should nd a text le named
“LoggerCD.txt” in it. When opened it would look something like this.
This le has data, but it would be hard to analyse them on a notepad. Hence we can open it on Excel as a CSV (Comma separated values)
file, thus making it more effective. To open in excel
1.Open Excel. Click on File->Open and select “All le” at bottom right corner and select the “LoggerCD” le from the SD card. This will open
a text import wizard.
2.Click on “Next” and select comma as a delimiter. Click on “Next” again. Then Finish.
3.Now your values will be opened in a Excel file as shown below
I have logged the values for every 5 seconds; you can log them for any desired time by changing the delay function in the program. For
detailed understanding of the working please watch the video below.
Hope you liked the project, if you have any doubt write them in the below comment section and I will help you out.
Bonus Improvement- Wireless Data Logging Using Arduino:
Once you have succeeded up to this point, then with few advancements and just adding a few lines of code you can log data wirelessly.
Simply connect a Bluetooth Device like HC-05 and write the data to PLX-DAQ via Bluetooth instead of Serial. That is replace
Serial.print(parameter); with BluetoothName.print(parameter); and connect your Laptop to your Bluetooth Module an select the COM port
to which your Laptops Bluetooth is connected and Taadaaa...... You have a working a Wireless Data Logging System in no time.
Code:
/*
* Program to demonstrate Data Logging/Visualisation using Arduino
*
* ###Connection with SD card module###
* Vcc->5V
* Gnd->Gnd
* MISO->pin 12
* MOSI->pin 11
* SCK-> pin 13
* CS-> pin 4
*
* ###Connection with DS3231###
* Vcc->5V
* Gns->Gnd
* SCL->pin A5
* SDA-> pin A4
*
* ###Connection with DT11###
* Vcc->5V
* Gnd->Gnd
* Out-> pin 7
*
*
*/
#include <DS3231.h> //Library for RTC module (Download from Link in article)
#include <SPI.h> //Library for SPI communication (Pre-Loaded into Arduino)
#include <SD.h> //Library for SD card (Pre-Loaded into Arduino)
#include <dht.h> //Library for dht11 Temperature and Humidity sensor (Download from Link in article)
#define DHT11_PIN 7 //Sensor output pin is connected to pin 7
dht DHT; //Sensor object named as DHT
const int chipSelect = 4; //SD card CS pin connected to pin 4 of Arduino
// Init the DS3231 using the hardware interface
DS3231 rtc(SDA, SCL);
void setup()
{
// Setup Serial connection
Serial.begin(9600);
Initialize_SDcard();
Initialize_RTC();
Initialize_PlxDaq();
}
void loop()
{
Read_DHT11();
Write_SDcard();
Write_PlxDaq();
delay(5000); //Wait for 5 seconds before writing the next data
}
void Write_PlxDaq()
{
Serial.print("DATA"); //always write "DATA" to Indicate the following as Data
Serial.print(","); //Move to next column using a ","
Serial.print("DATE"); //Store date on Excel
Serial.print(","); //Move to next column using a ","
Serial.print("TIME"); //Store date on Excel
Serial.print(","); //Move to next column using a ","
Serial.print(DHT.temperature); //Store date on Excel
Serial.print(","); //Move to next column using a ","
Serial.print(DHT.humidity); //Store date on Excel
Serial.print(","); //Move to next column using a ","
Serial.println(); //End of Row move to next row
}
void Initialize_PlxDaq()
{
Serial.println("CLEARDATA"); //clears up any data left from previous projects
Serial.println("LABEL,Date,Time,Temperature,Humidity"); //always write LABEL, to indicate it as first line
}
void Write_SDcard()
{
// open the file. note that only one file can be open at a time,
// so you have to close this one before opening another.
File dataFile = SD.open("LoggerCD.txt", FILE_WRITE);
// if the file is available, write to it:
if (dataFile) {
dataFile.print(rtc.getDateStr()); //Store date on SD card
dataFile.print(","); //Move to next column using a ","
dataFile.print(rtc.getTimeStr()); //Store date on SD card
dataFile.print(","); //Move to next column using a ","
dataFile.print(DHT.temperature); //Store date on SD card
dataFile.print(","); //Move to next column using a ","
dataFile.print(DHT.humidity); //Store date on SD card
dataFile.print(","); //Move to next column using a ","
dataFile.println(); //End of Row move to next row
dataFile.close(); //Close the file
}
else
Serial.println("OOPS!! SD card writing failed");
}
void Initialize_SDcard()
{
// see if the card is present and can be initialized:
if (!SD.begin(chipSelect)) {
Serial.println("Card failed, or not present");
// don't do anything more:
return;
}
// open the file. note that only one file can be open at a time,
// so you have to close this one before opening another.
File dataFile = SD.open("LoggerCD.txt", FILE_WRITE);
// if the file is available, write to it:
if (dataFile) {
dataFile.println("Date,Time,Temperature,Humidity"); //Write the first row of the excel file
dataFile.close();
}
}
void Initialize_RTC()
{
// Initialize the rtc object
rtc.begin();
//#### The following lines can be uncommented to set the date and time for the first time###
/*
rtc.setDOW(FRIDAY); // Set Day-of-Week to SUNDAY
rtc.setTime(18, 46, 45); // Set the time to 12:00:00 (24hr format)
rtc.setDate(6, 30, 2017); // Set the date to January 1st, 2014
*/
}
void Read_DHT11()
{
int chk = DHT.read11(DHT11_PIN);
}
/*void Read_DateTime()
{
// Send date
Serial.print(rtc.getDateStr());
Serial.print(" -- ");
// Send time
Serial.println(rtc.getTimeStr());
}*/
/*void Read_TempHum()
{
Serial.print("Temperature = ");
Serial.println(DHT.temperature);
Serial.print("Humidity = ");
Serial.println(DHT.humidity);
// delay(1000);
}*/
Video:
JLCPCB Prototype: Only $2 for 10 pcs PCBs, 48 Hours Quick Turn
China's Largest PCB Manufacturer, 290,000+ Customers & 8,000+ Online Orders Per Day
Up to $20 Shipping Discount on First order, Quote Online Now
Add new
comment
Comments (9)
reply
mark church
Very well described project and applications are endless thank you for the tutorial.
Jul 12, 2017
reply
Greg
Fun project. I would like to convert it to Fahrenheit. I've been trying for a bit and cannot get it to work. Could you post how to
change to Fahrenheit. Thank you very much
Jul 20, 2017
reply
keith.perry
looks very interesting
Aug 14, 2017
reply
Joe Huard
I like all of these instructions to do data logging. My project involves reading the Sentron PAC3200 sub-meter and saving it 4
times per day into a spreadsheet. I was thinking Arduino but have no experience with that. I see the direct writing to my
computer as the best and shortest solution, so can you tell me if the PLX-DAQ software plugin will work with Libre Office Calc?
If I had that running it would solve this problem, and the only remaining problem would be missing data from when the
computer shuts off due to a power outage. I could solve that by using a battery-backed up laptop or a UPS.
Or, even cheaper, an Arduino that can wake me up to re-boot my computer if and when it shut off when I was asleep.
Oct 24, 2017
reply
Arif
Very nice project. I appreciate this. Is it possible real time speed monitoring? We have 40 machine in a floor, we want to monitor
the real time speed of these machines. If possible what need to be done, pls help me to do this.
Dec 29, 2017
reply
Ola Dunk
Thanks for sharing this nice project.
I have tried to compile it with Aduino IDE v 1.8.5 and get a lot of errors about DHT missing class etc.
Are some header files missing ? Or do I need an older version to compile successfully ?
What else could be wrong ?
regards,
Ola
Feb 05, 2018
reply
AISHA
Did you download and add the DHT library to your IDE?
If not you will get this error
Feb 07, 2018
reply
Pashar
How do I find out to which port is my arduino connected?
Mar 21, 2018
reply
B.Aswinth Raj
https://www.arduino.cc/en/Reference/PortManipulation
This link explains which pins of Arduino is related to which pins
Mar 22, 2018
Leave a comment
Your name *
E-mail *
The content of this field is kept private and will not be shown publicly.
Subject
Comment *
No HTML tags allowed.
Web page addresses and e-mail addresses turn into links automatically.
Lines and paragraphs break automatically.
Save Preview
RELATED CONTENT
Interfacing Joystick with Arduino
Arduino Light Sensor Circuit using LDR
Arduino Ohm Meter
MPU6050 Gyro Sensor Interfacing with Arduino
Battery Voltage Indicator using Arduino and LED Bar Graph
LATEST POSTS
Wein Bridge Oscillator
Interfacing Joystick with Arduino
Implantable sensor relays real-time personal health data to a cell phone
Interfacing LCD with MSP430G2 LaunchPad
X-Class CMOS Image Sensor Platform from ON Semiconductor Enables New Functionality for Industrial Camera Design
RC Phase Shift Oscillator
ACTIVE FORUM TOPICS
Morelow voltage analog signal passing through microcontroller
RFID Hitag S 256 Technology for Racing Pigeon Timing device
I am new a member
Latest electrical engineering project
Assistance with science fair
USER LOGIN
E-mail or username *
Password *
Log in Create new account Request new password
FEATURED PROJECTS AND CIRCUITS
Capacitance
Measure
MP3
Fingerprint
Virtual
Smoke
IOT
DIY
Smart
How
Call
Arduino
Live
Blind
Sound/Noise
Power
Arduino
Player
Data
Reality
Speedometer
Detector
Robotic
based
Smart
Phone
to
and
Based
Temperature
Meter
Stick
Level
Bank
Make
Based
Circuit
Biometric
Logger
Arm
Raspberry
Vacuum
Controlled
Use
Message
Digital
and
using
in
Circuit
a
CNC
Attendance
(Log
MQ2
Pi
Cleaning
FM
NeoPixel
using
Clock
Humidity
Arduino
dB
Mini
Plotter
System
Temperature,
and
Gas
Home
Robot
Radio
LED
Arduino
with
Monitoring
with
Tesla
Machine
Humidity,
Processing
Sensor
Security
using
Strip
and
Alarm
over
Microphone
Coil
Time
Android
and
System
Arduino
with
GSM
Internet
9v
on
App
with
and
Arduino
Module
using
SD
Email
Processing
and
Arduino
Card
Alert
TFT
and
and
LCD
ThingSpeak
Computer) View all Featured Projects
Robotics | EE Projects | 555 Timer Circuits | ATmega32 Projects | ATmega8 Projects | Arduino Projects | Raspberry Pi Projects | IoT Projects | Arduino ESP8266 |
Calculators
SIGN UP FOR LATEST NEWS
Subscribe
Copyright © 2018 Circuit Digest. All rights Privacy policy | Disclaimer | Contact Us | Submit |
reserved. Advertise