24小时热门版块排行榜    

查看: 1392  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 0817 化学工程 299分求调剂 有科研经历 有二区文章 +13 rare12345 2026-03-18 13/650 2026-03-19 17:30 by jean5056
[考研] 0703化学调剂 +4 18889395102 2026-03-18 4/200 2026-03-19 16:13 by 30660438
[考研] 求调剂,一志愿:南京航空航天大学大学 ,080500材料科学与工程学硕,总分289分 +3 @taotao 2026-03-19 3/150 2026-03-19 14:07 by peike
[考研] 0703化学调剂 +8 妮妮ninicgb 2026-03-15 12/600 2026-03-19 05:55 by anny19840123
[考研] 330求调剂 +3 小材化本科 2026-03-18 3/150 2026-03-18 21:55 by 无懈可击111
[考研] 08工科 320总分 求调剂 +5 梨花珞晚风 2026-03-17 5/250 2026-03-18 14:49 by haxia
[考研] 311求调剂 +11 冬十三 2026-03-15 12/600 2026-03-18 14:36 by 星空星月
[考研] 302求调剂 +10 呼呼呼。。。。 2026-03-17 10/500 2026-03-18 12:45 by Linda Hu
[考研] 312求调剂 +8 陌宸希 2026-03-16 9/450 2026-03-18 12:39 by Linda Hu
[考研] 0703化学调剂 +3 妮妮ninicgb 2026-03-17 3/150 2026-03-18 10:29 by macy2011
[考研] 环境工程调剂 +8 大可digkids 2026-03-16 8/400 2026-03-18 09:36 by zhukairuo
[考研] 考研求调剂 +3 橘颂. 2026-03-17 4/200 2026-03-17 21:43 by 有只狸奴
[考研] 301求调剂 +4 A_JiXing 2026-03-16 4/200 2026-03-17 17:32 by ruiyingmiao
[考研] 326求调剂 +5 上岸的小葡 2026-03-15 6/300 2026-03-17 17:26 by ruiyingmiao
[考研] 070300化学学硕求调剂 +6 太想进步了0608 2026-03-16 6/300 2026-03-16 16:13 by kykm678
[考研] 0856专硕279求调剂 +5 加油加油!? 2026-03-15 5/250 2026-03-15 11:58 by 2020015
[考研] 本科南京大学一志愿川大药学327 +3 麦田耕者 2026-03-14 3/150 2026-03-14 20:04 by 外星文明
[考研] 304求调剂 +7 7712b 2026-03-13 7/350 2026-03-13 21:42 by peike
[考研] 308求调剂 +3 是Lupa啊 2026-03-12 3/150 2026-03-13 14:30 by 求调剂zz
[考博] 福州大学杨黄浩课题组招收2026年专业学位博士研究生,2026.03.20截止 +3 Xiangyu_ou 2026-03-12 3/150 2026-03-13 09:36 by duanwu655
信息提示
请填处理意见