24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1261  |  回复: 11
当前主题已经存档。
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

下雪天146

新虫 (初入文坛)

[交流] 【求助】求助 怎么编写C/C++程序读Excel文件数据

怎么编写C/C++程序读Excell文件数据
我在网上搜了一下,都很复杂,看不懂。
我只需将像读txt文本文件样,将数据读入内存

变量。

[ Last edited by nono2009 on 2009-11-17 at 13:39 ]
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

magic7004

金虫 (职业作家)

★ ★ ★ ★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
senlia(金币+5,VIP+0):您..辛苦了 11-20 18:06
今天有空,写了个简单的例子,搂住看看吧。我用VC++ 6.0 和 Office 2003做的。

用法:
首先创建或打开一个工程(MFC的或者Win32的都行),然后按下面步骤:

1、把文件ExcelOperation.h、ExcelOperation.cpp、Excel.h和Excel.cpp全部加入到工程中。
2、打开工程的StdAfx.h,如果里面没有#include,就加上这行。
3、选菜单Project-->Settings...,在Project Settings窗口中选C/C++标签,然后Catagory选Code Generation,然后Use run-time library选Multithreaded 或 Multithreaded Dll(看附件图片)。
4、在搂住自己的cpp中加入#include "ExcelOperation.h"就可以使用ExcelOperation类了。

类包含OpenXls,CreateXls,CloseXls,ReadCell,WriteCell 共5个成员函数,参数都很简单,用法看下面的例子。
CODE:
#include "stdafx.h"
#include "ExcelOperation.h"

int APIENTRY WinMain(HINSTANCE hInstance,
                     HINSTANCE hPrevInstance,
                     LPSTR     lpCmdLine,
                     int       nCmdShow)
{
        // TODO: Place code here.
        ExcelOperation excel;
        try
        {
                excel.CreateXls("D:\\sss.xls");        //创建D:\sss.xls
                excel.WriteCell(1,1,1,COleVariant("Hello! :-)"));        //向Sheet1的A1单元格写入字符串Hello! :-)
                COleVariant va = excel.ReadCell(1,1,1);        //读出Sheet1的A1单元格
                CString s("Sheet1!A1 =");
                s += va.bstrVal;
                MessageBox(NULL,s,NULL,MB_OK);        //用MessageBox显示其内容
                excel.CloseXls();        //保存并关闭sss.xls
        }
        catch(char* e)
        {
                MessageBox(NULL,e,NULL,MB_OK);
        }
        catch(...)
        {
                MessageBox(NULL,"Something Wrong! :-(", NULL, MB_OK);
        }
        return 0;
}

ps:随便写的,很粗糙,搂住可以自己加入需要的功能 和 错误处理代码。

[ Last edited by magic7004 on 2009-11-20 at 16:54 ]
流氓不可怕,可怕的是流氓有文化,有文化又BH的流氓无敌~~!
10楼2009-11-20 15:16:24
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 12 个回答

nono2009

超级版主 (文学泰斗)

No gains, no pains.

优秀区长优秀区长优秀区长优秀区长优秀版主

★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
余泽成(金币+1,VIP+0):谢谢参与应助! 11-17 16:11
先将excel文件另存为带格式的csv数据文件,然后就像读txt文件一样了。
2楼2009-11-17 13:38:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

magic7004

金虫 (职业作家)

★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
余泽成(金币+1,VIP+0):谢谢参与应助! 11-17 16:11
Excel可以当成数据库来读写,不过对数据格式貌似有限制,不推荐。

还有就是用com来操作excel了,可以实现excel的几乎所有功能,推荐。

[ Last edited by magic7004 on 2009-11-17 at 16:08 ]
流氓不可怕,可怕的是流氓有文化,有文化又BH的流氓无敌~~!
3楼2009-11-17 15:48:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

jjdg

版主 (知名作家)

优秀版主


还是用com方便!
努力学习!以正当途径!获得需要的知识!
4楼2009-11-17 18:57:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复(可上传附件)
信息提示
请填处理意见