24小时热门版块排行榜    

查看: 1390  |  回复: 11
当前主题已经存档。

下雪天146

新虫 (初入文坛)

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

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

变量。

[ Last edited by nono2009 on 2009-11-17 at 13:39 ]
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

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的回帖

下雪天146

新虫 (初入文坛)

感谢各位


jjdg(金币+1,VIP+0):用com啦!直接挂! 12-9 22:59
非常感谢各位。
但是我做的一个程序中,必须要用c/c++读Excel表中的数据,而且我只会C/C++,不会其他的语言
5楼2009-11-19 12:16:24
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

magic7004

金虫 (职业作家)


小木虫(金币+0.5):给个红包,谢谢回帖交流
汗下,搂住com不是语言的...
流氓不可怕,可怕的是流氓有文化,有文化又BH的流氓无敌~~!
6楼2009-11-19 12:21:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

magic7004

金虫 (职业作家)

★ ★
senlia(金币+2,VIP+0):请问能否详细讲解如何用com或者dao处理excel文件?谢谢 11-19 13:55
要么搂住用DAO把Excel当数据库吧。
流氓不可怕,可怕的是流氓有文化,有文化又BH的流氓无敌~~!
7楼2009-11-19 12:22:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

magic7004

金虫 (职业作家)

★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
余泽成(金币+2,VIP+0):专家辛苦了! 11-19 18:12
引用回帖:
senlia(金币+2,VIP+0):请问能否详细讲解如何用com或者dao处理excel文件?谢谢 11-19 13:55

详细讲解的话可以写本书了。
搂住既然需要操作excel,还是学习下com或者数据库的知识比较好。

ps:建议搂住用vb或者C#来做Excel的操作,简单很多的。至于计算部分,用C++做成Dll就好了。

ps2:搂住既然不会读写excel为什么一定要用excel呢?
搂住如果是为了学习的话,还是别怕麻烦,找本书看看。
如果只是要解决问题,那就想想变通的方法吧。比如按照沙发说的,做成csv(Comma Separated Values),它是纯文本的文件,每行是一条记录,记录中的每个字段用逗号(英文的)分隔开就行了。CSV可以用excel直接打开的。
流氓不可怕,可怕的是流氓有文化,有文化又BH的流氓无敌~~!
8楼2009-11-19 17:06:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wxl_23

★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
senlia(金币+2,VIP+0):感谢您的建议! 11-19 21:03
建议一下,可以用python来写呀,这样就可以读Excel文件的数据了。
9楼2009-11-19 20:00:58
已阅   回复此楼   关注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的回帖
相关版块跳转 我要订阅楼主 下雪天146 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 288求调剂 +9 于海海海海 2026-03-19 9/450 2026-03-19 15:34 by haoshis
[考研] 0817调剂 +3 没有答案_ 2026-03-14 3/150 2026-03-19 09:51 by Xu de nuo
[考研] 【同济软件】软件(085405)考研求调剂 +3 2026eternal 2026-03-18 3/150 2026-03-18 19:09 by 搏击518
[考研] 化学工程321分求调剂 +15 大米饭! 2026-03-15 18/900 2026-03-18 14:52 by haxia
[考研] 297求调剂 +8 戏精丹丹丹 2026-03-17 8/400 2026-03-18 14:30 by laoshidan
[考研] 277调剂 +5 自由煎饼果子 2026-03-16 6/300 2026-03-17 19:26 by 李leezz
[考研] 268求调剂 +8 一定有学上- 2026-03-14 9/450 2026-03-17 17:47 by laoshidan
[考博] 26申博 +4 八6八68 2026-03-16 4/200 2026-03-17 13:00 by 轻松不少随
[考研] 211本,11408一志愿中科院277分,曾在中科院自动化所实习 +6 Losir 2026-03-12 7/350 2026-03-17 12:09 by danranxie
[考研] 11408 一志愿西电,277分求调剂 +3 zhouzhen654 2026-03-16 3/150 2026-03-17 07:03 by laoshidan
[考研] [导师推荐]西南科技大学国防/材料导师推荐 +3 尖角小荷 2026-03-16 6/300 2026-03-16 23:21 by 尖角小荷
[考研] 304求调剂 +4 ahbd 2026-03-14 4/200 2026-03-16 16:48 by 我的船我的海
[考研] 285求调剂 +6 ytter 2026-03-12 6/300 2026-03-16 15:05 by njzyff
[考研] 288求调剂 +4 奇点0314 2026-03-14 4/200 2026-03-14 23:04 by JourneyLucky
[考研] 中科大材料专硕319求调剂 +3 孟鑫材料 2026-03-13 3/150 2026-03-14 18:10 by houyaoxu
[考研] 297一志愿上交085600求调剂 +5 指尖八千里 2026-03-14 5/250 2026-03-14 17:26 by a不易
[考研] 330求调剂 +3 ?酱给调剂跪了 2026-03-13 3/150 2026-03-14 10:13 by JourneyLucky
[考研] 329求调剂 +3 miaodesi 2026-03-12 4/200 2026-03-13 20:53 by 18595523086
[考研] 295求调剂 +3 小匕仔汁 2026-03-12 3/150 2026-03-13 15:17 by vgtyfty
[考研] 333求调剂 +3 152697 2026-03-12 4/200 2026-03-13 07:08 by Iveryant
信息提示
请填处理意见