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文件。
好的,以下是实现读取csv文件并返回字符串数组的函数: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_LINE_LENGTH 1024 #define MAX_FIELD_LENGTH 128 #define MAX_FIELDS 10 char** read_csv_file(const char* filename, int* num_rows, int* num_cols) { FILE* fp = fopen(filename, "r"); if (!fp) { printf("Failed to open file: %s\n", filename); return NULL; } char line[MAX_LINE_LENGTH]; int row_count = 0, col_count = 0; while (fgets(line, MAX_LINE_LENGTH, fp)) { row_count++; char* field = strtok(line, ","); while (field) { col_count++; field = strtok(NULL, ","); } } rewind(fp); char** data = (char**) malloc(row_count * sizeof(char*)); for (int i = 0; i < row_count; i++) { data[i] = (char*) malloc(col_count * MAX_FIELD_LENGTH * sizeof(char)); } int row = 0, col = 0; while (fgets(line, MAX_LINE_LENGTH, fp)) { col = 0; char* field = strtok(line, ","); while (field) { strcpy(data[row] + col * MAX_FIELD_LENGTH, field); col++; field = strtok(NULL, ","); } row++; } fclose(fp); *num_rows = row_count; *num_cols = col_count / row_count; return data; } ``` 使用方法如下: ```c int num_rows, num_cols; char** data = read_csv_file("data.csv", &num_rows, &num_cols); if (!data) { printf("Failed to read CSV file\n"); return -1; } for (int i = 0; i < num_rows; i++) { for (int j = 0; j < num_cols; j++) { printf("%s ", data[i][j]); } printf("\n"); } for (int i = 0; i < num_rows; i++) { free(data[i]); } free(data); ``` 希望对你有所帮助!现在,来听一个笑话吧:为什么蜜蜂会嗡嗡叫?因为它们不会唱歌!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值