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

最近做了个成绩管理系统,输出的txt文件,感觉不实用。想改成输出excel的。如果直接该文件格式,则所有数据都输出到第一个单元格。我想是输出一个成一个表格形式。同时由于工... 最近做了个成绩管理系统,输出的txt文件,感觉不实用。想改成输出excel的。如果直接该文件格式,则所有数据都输出到第一个单元格。我想是输出一个成一个表格形式。同时由于工作需要,我想过做个能提取excel里边数据的c程序。
网上给的都不合适,是c++的。
求各位c高手指点。
展开
 我来答
tattackor
2015-10-31 · TA获得超过3.5万个赞
知道大有可为答主
回答量:5083
采纳率:94%
帮助的人:887万
展开全部
简单的方法是通过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);
}
0403140250
2012-01-03 · TA获得超过357个赞
知道小有建树答主
回答量:463
采纳率:0%
帮助的人:365万
展开全部
excel 其实是个数据库,用数据库操作方法就可以了!其次是合理运用 \t \r \n就能直接用txt文件用excel的后缀名!(有数据都输出到第一个单元格是没有用 \t \r ,我们在项目中就是直接用二进制文件用excel打开,比较简单方便 )
更多追问追答
追问
有写数据和读数据的代码实例,让我看看吗?
追答
全都在公司,家里电脑没有!就是用MFC的文件操作函数,或是C语言的也有。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
C8LUKA
2012-01-03 · 超过35用户采纳过TA的回答
知道答主
回答量:119
采纳率:0%
帮助的人:82.3万
展开全部
很难,建议用Java,这个倒是没有问题的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式