CSV文件是常用的excel文件格式之一,行与行之间使用换行符分隔,每行的各个列使用逗号分隔。根据CSV的这特点,利用STL的vector容器,搭建了一个CSV读写的类,目前实现的api如下,具体代码见附件。
bool Create(const char *pcsvfile);//创建一个csv文件
bool Open(const char *pcsvfile);//打开一个csv文件
vector<string> GetRow(long row_index);//读取指定行的值,返回string的vector
vector<string> GetColumn(long col_index);//读取指定列的值,返回string的vector
vector<string> operator[](long row_index);//使用[][]读取单元格,只能做右值
string GetCell(long row_index, long col_index);//读取row_index行col_index单元格数据
bool InserRow(long row_index, vector<string> row_data);//在row_index位置插入行
bool InserColumn(long col_index, vector<string> col_data);//在col_index位置插入列
bool DeletRow(long row_index);//删除row_index行
bool DeletColumn(long col_index);//删除col_index列
bool DeletRow(long col_index, const char *key);//以col_index列为查找源,删除=key的行
bool DeletColumn(long row_index, const char *key);//以row_index行为查找源,删除=key列
bool UpdateRow(long row_index, vector<string> row_data);//更新row_index行数据
bool UpdateColumn(long col_index, vector<string> col_data);//更新col_index列数据
bool UpdateCell(long row_index, long col_index, const char *data);//更新row_index行col_index列单元格
long GetColumnIndex(long row_index, const char *key);//以row_index行为查找源,提取=key的列索引号
long GetRowIndex(long col_index,const char *key);//以col_index列为查找源,提取=key的行索引号
long GetTotalRow();//获取表格的总行数
long GetTotalColumn();//获取表格的总列数
double Sum(long left_row, long top_col, long right_row, long down_col);//对left_row行top_col列 到 right_row行down_col列范围的数字求和, 忽略非数字单元格
double Avg(long left_row, long top_col, long right_row, long down_col); // 对left_row行top_col列 到 right_row行down_col列范围的数字求均值, 忽略非数字单元格
bool Save(const char *pcsvfile = NULL);//保存CSV,文件名为pcsvfile
friend ostream& operator<<(ostream& out, MyCSV &obj);
void PrintCSV();//打印CSV表格