Skip to content

Latest commit

 

History

History
122 lines (118 loc) · 2.47 KB

README.md

File metadata and controls

122 lines (118 loc) · 2.47 KB

CSVWriter

Simple c++ csv writer class.

How to use ?

just c&p or add the CSVWriter.h file to your project.

write a single row

CSVWriter csv;
csv << "this" << "is" << "a" << "row";
cout << csv << endl;

output:

this;is;a;row

write multiple rows

CSVWriter csv;
csv.newRow() << "this" << "is" << "the" << "first" << "row";
csv.newRow() << "this" << "is" << "the" << "second" << "row";
cout << csv << endl;

output:

this;is;the;first;row
this;is;the;second;row

auto row

When each row has a fixed number of colums, CSVWriter can add rows automatically. In this example, each row has 5 colums:

CSVWriter csv;
csv.enableAutoNewRow(5);
csv << "this" << "is" << "the" << "first" << "row" << "this" << "is" << "the" << "second" << "row";
cout << csv << endl;

output:

this;is;the;first;row
this;is;the;second;row

write csv to filesystem

CSVWriter csv;
csv.newRow() << "this" << "is" << "the" << "first" << "row";
csv.newRow() << "this" << "is" << "the" << "second" << "row";
csv.writeToFile("foobar.csv");

append csv to existing file

CSVWriter csv;
csv << "append" << "this" << "row" << "please" << ":)";
csv.writeToFile("foobar.csv",true);

change seperator

CSVWriter csv(",");
csv << "this" << "is" << "a" << "row";
cout << csv << endl;

output:

this,is,a,row

merge two CSVWriters

CSVWriter csv_a;
CSVWriter csv_b;
csv_a << "this" << "comes" << "from" << "csv_a";
csv_b << "this" << "is" << "from" << "csv_b";
csv_b += csv_a;
cout << csv_b << endl;

output:

this;is;from;csv_b
this;comes;from;csv_a

supported datatypes

CSVWriter uses a stringstream to serilize values. Each datatype supported by << operator from stringstresm can be used:

char c = 'c';
bool b = false;
short s = 6000;
int i = 300000;
float f = 3.14159;
double d = 4.85875e-270;
string str = "hello world";
char c_str[] = "whats up";
CSVWriter csv;
csv << c << b << s << i << f << d << str << c_str ;
cout << csv;

output:

c;0;6000;300000;3.14159;4.85875e-270;hello world;whats up

As you can see, boolean values are serilized to 0 for false and 1 for true.

escaping

CSVWriter can escape your seperator

CSVWriter csv;
csv << "escape;me;please";
cout << csv << endl;

output:

"escape;me;please"

CSVWriter can also escape quotation marks

CSVWriter csv;
csv << "escape\"me\"please\"\":)";
cout << csv << endl;

output:

"escape""me""please"""":)"