如何用C语言读入和输出excel里的数据?

最近做了个成绩管理系统,输出的txt文件,感觉不实用。想改成输出excel的。如果直接该文件格式,则所有数据都输出到第一个单元格。我想是输出一个成一个表格形式。同时由于工作需要,我想过做个能提取excel里边数据的c程序。
网上给的都不合适,是c++的。
求各位c高手指点。

简单的方法是通过ODBC来实现:
具体实现
一、 包含Excel文件操作类头文件
#include "CSpreadSheet.h"
二、 新建Excel文件,并写入默认数据
// 新建Excel文件名及路径,TestSheet为内部表名
CSpreadSheet SS("c:\\Test.xls", "TestSheet");

CStringArray sampleArray, testRow;

SS.BeginTransaction();

// 加入标题
sampleArray.RemoveAll();
sampleArray.Add("姓名");
sampleArray.Add("年龄");
SS.AddHeaders(sampleArray);

// 加入数据
CString strName[] = {"徐景周","徐志慧","郭徽","牛英俊","朱小鹏"};
CString strAge[] = {"27","23","28","27","26"};
for(int i = 0; i < sizeof(strName)/sizeof(CString); i++)
{
sampleArray.RemoveAll();
sampleArray.Add(strName[i]);
sampleArray.Add(strAge[i]);
SS.AddRow(sampleArray);
}

SS.Commit();

三、 读取Excel文件数据
CSpreadSheet SS("c:\\Test.xls", "TestSheet");

CStringArray Rows, Column;

//清空列表框
m_AccessList.ResetContent();
for (int i = 1; i <= SS.GetTotalRows(); i++)
{
// 读取一行
SS.ReadRow(Rows, i);
CString strContents = "";
for (int j = 1; j <= Rows.GetSize(); j++)
{
if(j == 1)
strContents = Rows.GetAt(j-1);
else
strContents = strContents + " --> " + Rows.GetAt(j-1);
}

m_AccessList.AddString(strContents);
}
温馨提示:内容为网友见解,仅供参考
第1个回答  2012-01-03
excel 其实是个数据库,用数据库操作方法就可以了!其次是合理运用 \t \r \n就能直接用txt文件用excel的后缀名!(有数据都输出到第一个单元格是没有用 \t \r ,我们在项目中就是直接用二进制文件用excel打开,比较简单方便 )追问

有写数据和读数据的代码实例,让我看看吗?

追答

全都在公司,家里电脑没有!就是用MFC的文件操作函数,或是C语言的也有。

追问

写一段短的C程序也可.我主要是想看看读写数据时,数据如何换行输入输出,换列输入输出.

追答

fprintf(%d\t%d\t%f\n"",a,b,c)
fprintf(\t%d\t%d\t%f\n"",d,e,f)
a,B,c是不同的列,d在b的下面,e在C下一行,f在e右边一列!

以上用excel打开二进制文件!

追问

读数据怎么读?

本回答被提问者采纳
第2个回答  2012-01-03
很难,建议用Java,这个倒是没有问题的
相似回答