24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1473  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 国自然面上和省基金B类撒花 +6 花田半亩~白 2026-04-21 6/300 2026-04-22 10:55 by 3126142009
[教师之家] 又一批高校组建人工智能学院 师资行吗 不是骗人吗 +5 yexuqing 2026-04-19 5/250 2026-04-22 10:01 by easeheart
[论文投稿] 急需审稿人!!! +3 陆小果画大饼 2026-04-21 3/150 2026-04-21 23:54 by jzy_123456
[考博] 申博/考博 +4 啃面包的小书虫 2026-04-17 8/400 2026-04-21 16:26 by 啃面包的小书虫
[考研] 一志愿A区211,22408 321求调剂 +7 随心所欲☆ 2026-04-15 8/400 2026-04-21 08:22 by Equinoxhua
[考研] 295分求调剂 +6 ?要上岸? 2026-04-17 6/300 2026-04-21 08:18 by Equinoxhua
[考研] 一志愿中科大材料与化工,353分还有调剂学校吗 +11 否极泰来2026 2026-04-15 13/650 2026-04-20 22:31 by Equinoxhua
[考研] 085600材料与化工调剂 5+3 孜孜不倦2002 2026-04-19 6/300 2026-04-20 21:25 by babero
[论文投稿] 期刊推荐 +3 材料研究生 2026-04-15 5/250 2026-04-20 16:02 by 豆豆7758
[论文投稿] 有没有接收比较快的sci期刊呀,最好在一个月之内的,研三孩子求毕业 20+4 之护着 2026-04-16 7/350 2026-04-20 15:45 by 豆豆7758
[考研] 337求调剂 +3 jyz04 2026-04-18 3/150 2026-04-20 12:24 by 研可安
[考博] 申博 +3 Xyyx. 2026-04-18 3/150 2026-04-20 10:44 by YuY66
[考研] 求计算机方向调剂 +3 Toffee2 2026-04-16 6/300 2026-04-19 22:37 by ll叶
[考研] 294求调剂 +8 淡然654321 2026-04-17 9/450 2026-04-19 19:51 by Equinoxhua
[考研] 求调剂 +10 小聂爱学习 2026-04-16 12/600 2026-04-19 16:51 by 中豫男
[考研] 求调剂 +6 苦命人。。。 2026-04-18 7/350 2026-04-19 16:27 by 中豫男
[考研] 300求调剂 +12 橙a777 2026-04-15 12/600 2026-04-18 23:51 by 路病情
[考研] 收到复试调剂但是去不了 +8 小蜗牛* 2026-04-16 8/400 2026-04-18 11:15 by zixin2025
[考研] 260求调剂 +4 Zyt1314520.. 2026-04-17 5/250 2026-04-18 08:28 by babysonlkd
[考研] 322求调剂 +6 tekuzu 2026-04-17 6/300 2026-04-17 13:48 by Espannnnnol
信息提示
请填处理意见