Logging Arduino Serial Output to CSV/Excel (Windows/Mac/Linux)
![]() |
Written by Indrek Luuk
|
I have written a plug-in for Arduino IDE to save serial data as a CSV file that you can open in any spreadsheet application - like Microsoft Excel or LibreOffice.
data:image/s3,"s3://crabby-images/0b7bc/0b7bc3cb425101a68bfca15c24f6e9800df049b1" alt="ArduSpeadsheet Arduino IDE plug-in"
Video Tutorial
In this video, I will show you how to install and use the plug-in.
Installation
Extract the zip file and copy the "ArduSpreadsheet" folder into your Arduino "tools" folder next to the Arduino "libraries" folder. If the "tools" folder doesn't exist, then you can create it yourself.
C:\Users\<username>\Documents\Arduino\tools
/Users/<username>/Documents/Arduino/tools
data:image/s3,"s3://crabby-images/6f6f6/6f6f62dbc0ba0caa4f07c65a5266f86a40e6ff41" alt="ArduSpeadsheet in Arduino 'tools' folder"
Now restart your Arduino IDE, and you should see "ArduSpreadsheet" under the "Tools" menu.
data:image/s3,"s3://crabby-images/8d22a/8d22a53922976c4df4965e67d6da403d99bd480b" alt="ArduSpreadsheet in the Arduino IDE tools menu"
Arduino code
You can use the Arduino Serial library to send data for logging.
The baud rate parameter has to match with the selection in the ArduSpreadsheet window.
void setup() {
Serial.begin(9600);
}
data:image/s3,"s3://crabby-images/0b7bc/0b7bc3cb425101a68bfca15c24f6e9800df049b1" alt="ArduSpeadsheet Arduino IDE plug-in"
- tab - '\t'
- comma - ','
- semicolon - ';'
You can indicate the end of the row by calling "Serial.println()" or printing out a newline symbol '\n'.
Example
int rowCount = 500;
int rowNumber = 0;
void setup() {
Serial.begin(9600);
}
void loop() {
if (rowNumber < rowCount) {
Serial.print(++rowNumber);
Serial.print('\t');
if (rowNumber % 2 == 0) {
Serial.print("even\t");
} else {
Serial.print("odd\t");
}
Serial.println(random(16000), HEX);
}
}
The above code will produce this result:
data:image/s3,"s3://crabby-images/0b7bc/0b7bc3cb425101a68bfca15c24f6e9800df049b1" alt="ArduSpeadsheet Arduino IDE plug-in"
Running ArduSpreadsheet as a stand-alone program
To run it as a stand-alone program, you need to install Java 1.8 or newer.
I have included execution scripts for Windows, Mac, and Linux (all they do is execute the Main method inside ArduSpreadsheet.jar).
On Windows
Double-click on the "Windows_ArduSpreadsheet.bat." You may get a warning that you are executing an unrecognized app.
data:image/s3,"s3://crabby-images/dd5a5/dd5a5471c5195c51c2edc00bce8bea468b70bc4a" alt="ArduSpreadsheet in the Arduino IDE tools menu"
Click on "More info" and then "Run anyway."
data:image/s3,"s3://crabby-images/af4fa/af4fa8194f3f8eea095bc51b0fef37755792027a" alt="ArduSpreadsheet in the Arduino IDE tools menu"
On Mac
To get it running on Mac, you first need to give execution privileges to the script file.
$ chmod a+x Mac_ArduSpreadsheet.command
Then double-click on the "Mac_ArduSpreadsheet.command."
Mac OS will warn that the application is from an unknown developer.
data:image/s3,"s3://crabby-images/dc929/dc929c662c6d4df507ff4be647a3d81f25b57bb3" alt="ArduSpeadsheet Arduino IDE plug-in"
Open "System Preferences..." and then "Security & Privacy."
data:image/s3,"s3://crabby-images/5b994/5b994daf248a8524758872cb9329aa4ff2a4de3a" alt="ArduSpeadsheet Arduino IDE plug-in"
Click "Open Anyway" and then "Open"
data:image/s3,"s3://crabby-images/d9340/d9340b5b60a56b4a016e0b05208fc6d7048017a9" alt="ArduSpeadsheet Arduino IDE plug-in"
Now you can Open ArduSpreasheet by double-clicking on the "Mac_ArduSpreadsheet.command."
On Linux
$ chmod a+x Linux_ArduSpreadsheet.sh
Now you should be able to run the application by either executing the script from the command line or double-clicking on the "Linux_ArduSpreadsheet.sh."