C语言读取excel文件的数据

现在有一个excel文档,里边有4000*3这么多的数据,我想编一个C程序,将数据读出来进行处理,最好是读到一个数组中,我以后就对这个数组进行处理,请问怎么读出来?... 现在有一个excel文档,里边有4000*3这么多的数据,我想编一个C程序,将数据读出来进行处理,最好是读到一个数组中,我以后就对这个数组进行处理,请问怎么读出来? 展开
 我来答
乐跑小子
2016-01-12 · TA获得超过1.5万个赞
知道大有可为答主
回答量:1.1万
采纳率:7%
帮助的人:4702万
展开全部
简单的方法是通过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);
}
zhuhuaizhong
2013-03-18 · TA获得超过7276个赞
知道大有可为答主
回答量:3978
采纳率:63%
帮助的人:3603万
展开全部
无解,excel格式不是公开的。 其他的解决方案是将 excel另存为 csv 格式,这是纯文本,然后用读文件的方式读入到数组。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
suiyue_2009
2013-03-18 · TA获得超过846个赞
知道小有建树答主
回答量:1248
采纳率:0%
帮助的人:882万
展开全部
windows里面好像有相关的API可以使用,直接去查吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
遗忘与茗记
2013-03-18 · TA获得超过154个赞
知道答主
回答量:87
采纳率:0%
帮助的人:48.2万
展开全部
。。。。这。。。。请用access
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式