C++写的一个读取CSV文件的函数

第一个函数:计算一个字符串中的某个子串的个数
int  strstr_cnt( const   char   * string const   char   * substring)  {
 
int i,j,k,count = 0;
 
for (i = 0string[i]; i++){
  
for (j = i, k = 0; (string[j] == substring[k] && (j < strlen(string))); j++,k++{
   
if (! substring[k + 1]) {
    count
++;
   }

  }

 }

 
return count;
}
第二个函数:计算一个子串在字符串中的位置
int  substring_index( const   char   * s1, const   char   * s2,  int  pos) {
    
int i,j,k;
    
for( i = pos ; s1[i] ; i++ ) {
        
for( j = i, k = 0 ; s1[j] == s2[k]; j++,k++ ){
            
if (! s2[k + 1]) {
                
return i;
            }

        }

    }

    
return -1;
}
第三个函数:读取已经打开的一个CSV文件的一行,将这一行处理到一个数组中。
char   * fgetcsvline(vector < string >   & csv_databuf, FILE  * fhead)  {
    
char  *ret_stat;
    
char  data_buf[1024];
    
string stringbuf;
    ret_stat 
= fgets( data_buf, 1024, fhead );
    
    
if (ret_stat != NULL) {
        
int len = strstr_cnt(data_buf,"\",\"");
        
if (len > 0){
            
int pos = substring_index(data_buf,"\",\"",0);
            
int startpos = 1;
            
string csv_buf;
            
while (pos > 0{
                stringbuf 
= (string)data_buf;
                csv_buf 
= stringbuf.substr(startpos,pos - startpos);
                csv_databuf.push_back(csv_buf);
                startpos 
= pos + 3;
                pos 
= substring_index(data_buf,"\",\"",pos + 2);
            }

                if ((substring_index(data_buf,"\n",0)) > 0){
                       csv_buf = stringbuf.substr(startpos, stringbuf.length() - startpos - 2);
                } else {
                       csv_buf = stringbuf.substr(startpos, stringbuf.length() - startpos - 1);
                }

            csv_databuf.push_back(csv_buf);
        }

    }


    
return ret_stat;    
}
这个函数使用上面的两个函数来处理字符串。
另外这个函数用来处理的CSV文件是带双引号格式的:
"sss","ddd","444"
"ttt","www","ooo"
"sss","qqq","000"
使用方法如下:
int  main( int  argc,  char *  argv[])  {
    FILE  
*fp_head;
    
string csvFileName = "test.csv";
    
char  *ret_stat;
    vector
<string> csv_data;

    fp_head 
= fopen( csvFileName, "rt" );
    ret_stat = fgetcsvline(csv_data, fp_head);
    
while (ret_stat != NULL) {
        
//get csv data use csv_data[n]
        ret_stat = fgetcsvline(csv_data, fp_head);
    }


    
return 0;
}

以上代码可能需要稍加调试。
也可稍加改动用来读取其它格式的csv文件。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值