C++读写CSV文件

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表格

https://download.csdn.net/download/u010947832/12100249

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值