c语言实现读取csv文件,并对数据进行分析。

总代码:

```c在这里插入代码片
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct Student
{
char shuzu[20];

}students[8][21];
int main()
{
int i=0,k=0,q=0;
FILE *fp = NULL;

char *line,*record;

char buffer[1024];
float a[8][21]={0};
if ((fp = fopen(“C:\Users\throb\Desktop\温度.csv”, “at+”)) != NULL)
{
fseek(fp, 0L, SEEK_SET); //定位到第二行,每个英文字符大小为1
char delims[] = “,”;
char *result = NULL;
int j = 0;
while ((line = fgets(buffer, sizeof(buffer), fp))!=NULL)//当没有读取到文件末尾时循环继续
{
record = strtok(line, “,”);

while (record != NULL)//读取每一行的数据
{

printf("%s ", record);//将读取到的每一个数据打印出来
strcpy(students[i][k].shuzu,record);
k++;
record = strtok(NULL, “,”);
j++;

}
i++;
k=0;
printf("\n");
j = 0;
}
fclose(fp);
fp = NULL;
}

for(i=0;i<8;i++)
{
for(k=0;k<21;k++)
{
a[i][k]=atof(students[i][k].shuzu);
}
}
printf("\n");
printf("=============\n");
for(i=2;i<8;i++)
{
for(k=1;k<21;k++)
{
if(a[i][k]>37.0)
{
printf("%s\n",students[i][0].shuzu);
printf("%s\n",students[0][k].shuzu);
printf("%s\n",students[i][k].shuzu);
q++;

}                 

}
}
printf("=============\n");
printf(“人数%d人”,q);
}

为了读取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、付费专栏及课程。

余额充值