c语言获取表格数据

任务

虽然数据处理拥有多种便捷语言支持,但课设需要使用c语言实现,因此学习如何将excel表格信息导入程序中进行处理

所需

  • c语言运行平台
  • 数据表格

步骤

1.查阅发现,通过处理csv(comma separated-values)文件,在python学习时接触到,为逗号分隔的文本格式,可以被和文本文件相同方式处理。
2.将表格另存为csv格式。
打开excel表格,点击另存为

3.读入文件

FILE* fp;
fp = fopen("oneturntask.csv", "r");

4.目标为写一个读文件的模板,可以通过修改简单的参数,灵活读入不同文件的数据,方便多次使用

  • 读入表头信息
#define HEADERMAXLEN 100 //表头最大字符总长
#define TITLEMAXLEN 100 //单个标题最大字符长度
#define TITLEMAXNUM 20 //标题最大数量
int colNum=0;//记录表格数据总列数
int lineCodeCol, leaveTimeCol, directionCol, actualTimeCol;//记录需要的数据所在列数
char csvHeader[HEADERMAXLEN];//存储表头信息
char title[TITLEMAXNUM][TITLEMAXLEN];//存储各个标题
int lineData[TITLEMAXNUM];//读入数据
int readAll = 0;//判断是否到文件结尾

char* pHeader;
char* pTitle;

fscanf(fp, "%s", &csvHeader);//读入表头信息
//cout << "表头全部信息如下:" << csvHeader << endl;

for (pHeader = csvHeader; *pHeader != '\0'; pHeader++)
 { 
  	colNum++;//空出0号存储位置,与实际列数相一致
  	pTitle = title[colNum];
  	while (*pHeader != ',' && *pHeader != '\0')
  	{   
   		*pTitle++ = *pHeader++; 
  	}
  	*pTitle = '\0';  
  	//  cout << "第"<<colNum<<"列:"<<title[colNum] << endl;
  	if (*pHeader == '\0')//读到表头末尾退出循环
   		break;  
 }
 //cout << "共有数据:" << colNum << "列" << endl;
  • 定位所需数据
#define LINECODE "LineCode"
#define LEAVETIME "LeaveTime0"
#define ACTUALTIME  "ActualTime"
#define DIRECTION "WorkDirection"//表头关键字预定义
for (int i = 1; i <= colNum; i++)
{ 
  if (strcmp(title[i], LINECODE) == 0)
  {
   	lineCodeCol = i;
   	//cout << "所需" << LINECODE << "位于第" << i << "列" << endl;
  }
   
  if (strcmp(title[i], LEAVETIME) == 0)
  {
   	leaveTimeCol = i;
   	//cout << "所需" << LEAVETIME << "位于第" << i << "列" << endl;
  }
   
  if (strcmp(title[i], DIRECTION) == 0)
  {
   	directionCol = i;
   	//cout << "所需" << DIRECTION << "位于第" << i << "列" << endl;
  }
   
  if (strcmp(title[i], ACTUALTIME) == 0)
  {
   	actualTimeCol = i;
   	//cout << "所需" << ACTUALTIME << "位于第" << i << "列" << endl;
  }   
  • 读入所需数据
while (readAll==0)
{
	for (int i = 1; i <= colNum; i++)
  	{
   		if (fscanf(fp, "%d", &lineData[i]) == EOF)//判断读到文件末尾
   		{
   			 readAll = 1;
    			 break;
  		}
    
   		fgetc(fp);
 	}
 	//打印文件信息
 	/*
 	if (readAll == 0)
  	{
  		for (int i = 1; i <= colNum; i++)
   		{
    			if (i == lineCodeCol)
     				cout << "lineCode:" << lineData[i] << " ";
   			if (i == leaveTimeCol)
     				cout << "leaveTime:" << lineData[i] << " ";
     			if (i == actualTimeCol)
     				cout << "actualTime:" << lineData[i] << " ";
    			if (i == directionCol)
     				cout << "direction:" << lineData[i] << " ";
   		}
   	}
   	*/
}

5.能够对文件信息在读取后进行处理,关闭文件

fclose(fp);

结果验证

在这里插入图片描述

在这里插入图片描述

写在后面

想读取其他文件做调整时发现,可移植性并不优秀,面对表格中的字符数据处理显出无力,只能手动删除所有包含字符单元列进行测试。

优化想法:

对单元格的读取函数做封装:一次读取一个单元格全部内容至字符数组保存,之后再进行处理。

  • 9
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
提取 Excel 表格中的数据需要使用第三方库来完成,C 语言中比较常用的有 libxls 和 libxlsxwriter。 libxls 是一个 C 语言库,用于解析 Excel 97-2004 文件格式(.xls),可以读取 Excel 文件中的数据并将其转换为 C 语言中的数据类型。libxlsxwriter 则是一个 C 语言库,用于创建 Excel 文件并将数据写入其中,支持 Excel 2007+ 文件格式(.xlsx)。 以下是使用 libxls 库提取 Excel 表格数据的简单示例代码: ```c #include <stdio.h> #include <stdlib.h> #include "xls.h" int main(int argc, char *argv[]) { xlsWorkBook *workbook; xlsWorkSheet *worksheet; xlsCell *cell; int i, j; if (argc < 2) { printf("Usage: %s filename.xls\n", argv[0]); return 0; } // 打开 Excel 文件 workbook = xls_open(argv[1], "UTF-8"); if (workbook == NULL) { printf("Error: Unable to open file %s\n", argv[1]); return 1; } // 获取第一个工作表 worksheet = xls_getWorkSheet(workbook, 0); // 遍历表格中的每一个单元格 for (i = 0; i <= worksheet->rows.lastrow; ++i) { for (j = 0; j <= worksheet->rows.lastcol; ++j) { cell = xls_cell(worksheet, i, j); if (cell != NULL) { // 输出单元格的值 printf("%s\t", cell->str); } } printf("\n"); } // 关闭 Excel 文件 xls_close(workbook); return 0; } ``` 以上代码使用了 libxls 库的 API 来打开 Excel 文件获取工作表、遍历单元格并提取单元格的值。使用 libxlsxwriter 库也类似,只需要使用不同的 API 来创建 Excel 文件并将数据写入其中。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值