1.首先将excel文件转换为scv文件
原表格文件
、
转换为scv文件
此时使用notepad++打开可以看到文件已经变为了以英文逗号分割的字符串
见文件处理后
进行编码
代码处理
#include <stdio.h>
#include <string.h>
struct student_score{
char grade_i[32];
char name_i[32];
char subject_i[32];
int score_i;
};
static int pro_function(struct student_score* pro_in)
{
//具体处理逻辑 这里做简单打印处理
if(pro_in == NULL) return 0;
printf("班级[%s]姓名[%s]科目[%s]分数[%d] \n", pro_in->grade_i, pro_in->name_i, pro_in->subject_i, pro_in->score_i);
return 0;
}
int main(int argc, char* argv[])
{
if(argc < 2)
{
printf("请输入:程序名 文件名");
return -1;
}
FILE *fp = fopen(argv[1], "r");
if(fp == NULL)
{
printf("fopen [%s] error", argv[1]);
return -1;
}
int i = 0;
char linebuff[1024] = {0};
char linebuff1[1024] = {0};
int leng_out = 0;
char linebuff_out[2048] = {0};
struct student_score stcin = {0};
while(fgets(linebuff1, sizeof(linebuff1)-1, fp) != NULL)
{
//这里读取到一行,一行一行处理,主要使用strtok函数进行分割字符串处
strcpy(linebuff, strtok(linebuff1, "\n"));
strcpy(stcin.grade_i , strtok(linebuff, ","));
strcpy(stcin.name_i , strtok(NULL, ","));
strcpy(stcin.subject_i , strtok(NULL, ","));
stcin.score_i = atoi(strtok(NULL, ","));
// 将解析到的文件内容进行处
if(pro_function(&stcin))
{
printf("pro_function error");
return -1;
}
}
return 0;
}
程序运行结果