C语言读取csv文件的两种方法

打开csv文件

FILE* fp = NULL;
fp = fopen("D:\\Cerebellum\\Saverand_t5.csv", "at+");
if (fp != NULL)
	printf("打开文件成功!!\n");
else printf("失败!!\n");

方法一:一次获取所有字符,用strtok函数分割(字符少的情况下使用)

char* line,* p;//字符指针
char buffer[60],s[60];//存储所有字符
const char* delim = ",";
int k = 0;
	//一次获取所有字符,用strtok进行分割
fseek(fp, 0L, SEEK_SET);
line = fgets(buffer,60,fp);//先获取所有
strcpy(s, line);//字符指针转给字符常量,否则不能用strtok
printf("s=%s\n", s);
p = strtok(s, delim);
while (p != NULL && k < 10) {//以10个数为例
	a[k] = atof(p);//字符型转换为浮点型
	printf("a[%d]=%f\n",k, a[k]);
	p = strtok(NULL, delim);
	k++;
}

方法二:每次取逗号前的一个数,用strstr函数查找逗号位置后一位继续查找字符(字符多的情况下使用)

char* line,* ptr;//字符指针
char buffer[10];
char* p;
int N;
N=10;//以10个数为例
p = 0L;//设置初始查找位置
for (int k = 0; k < N; k++) {
	fseek(fp, p, 0);
	line = fgets(buffer,10,fp);
	if (line != NULL) {
		ptr = strstr(buffer, ",");//返回第一次出现逗号的指针
		if(ptr != NULL) {
			*ptr = '\0';//将逗号赋为结束符
			a[k] = atof(buffer);
			p = p + strlen(buffer) + 1;//前一次查找位置+输出的字符数+1=下一次查找的起点
		}
		else//ptr为NULL时,输出最后一个
			a[k] = atof(buffer);
	}
	else 
		break;
}
  • 3
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了读取CSV文件中的数据,可以使用C语言中的文件操作函数和字符串处理函数。具体步骤如下: 1. 打开CSV文件,使用fopen()函数打开文件,并使用文件指针指向该文件。 2. 读取CSV文件中的每一行数据,使用fgets()函数逐行读取CSV文件中的数据,并将其存储在一个字符数组中。 3. 将每一行数据按照逗号分隔符进行分割,使用strtok()函数将每一行数据按照逗号分隔符进行分割,并将分割后的每个字段存储在一个字符数组中。 4. 将分割后的数据进行处理,使用atof()函数将字符数组中的字符串转换为浮点数,并将其存储在一个数组中。 5. 关闭CSV文件,使用fclose()函数关闭文件。 下面是一个示例代码,可以读取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 int main() { FILE *fp; char line[MAX_LINE_LENGTH]; char *field; char fields[MAX_FIELDS][MAX_FIELD_LENGTH]; double data[MAX_FIELDS][MAX_FIELDS]; int i, j, num_fields = 0; fp = fopen("data.csv", "r"); if (fp == NULL) { printf("Failed to open file\n"); return 1; } while (fgets(line, MAX_LINE_LENGTH, fp) != NULL) { num_fields = 0; field = strtok(line, ","); while (field != NULL && num_fields < MAX_FIELDS) { strcpy(fields[num_fields], field); num_fields++; field = strtok(NULL, ","); } for (i = 0; i < num_fields; i++) { data[i][j] = atof(fields[i]); } j++; } fclose(fp); // 打印读取数据 for (i = 0; i < num_fields; i++) { for (j = 0; j < num_fields; j++) { printf("%f ", data[i][j]); } printf("\n"); } return 0; } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值