_Application m_ExlApp;   //组件服务器的各个classes
    _Workbook m_ExlBook;
    Workbooks m_ExlBooks;
    _Worksheet m_ExlSheet;
    Worksheets m_ExlSheets;
    //    LPDISPATCH lpDisp;
    Range m_ExlRge, usedRange;
 
       if(!m_ExlApp.CreateDispatch("Excel.Application",NULL))
       
              AfxMessageBox("创建Excel服务失败!"); 
              return
       }
 
       //设置为可见 
       m_ExlApp.SetVisible(TRUE); 
 
       ///////////////////下面得到应用程序所在的路径/////////////////// 
       CString theAppPath,theAppName; 
       char Path[MAX_PATH]; 
 
       GetModuleFileName(NULL,Path,MAX_PATH);//得到应用程序的全路径 
       theAppPath=(CString)Path; 
 
       theAppName=AfxGetApp()->m_pszAppName; 
       theAppName+=".exe"
 
       //把最后的文件名去掉 
       int length1,length2; 
 
       length1=theAppPath.GetLength(); 
       length2=theAppName.GetLength(); 
 
       theAppPath.Delete(length1-length2,length2); 
    //////////////////////////////////////////////////////////////// 
 
    COleVariant covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);
 
    // Get the Workbooks collection so that you can add a new workbook
    m_ExlBooks.AttachDispatch(m_ExlApp.GetWorkbooks());  // 得到Workbooks
    m_ExlBook = m_ExlBooks.Add(covOptional);     // 得到Workbook
 
 //      m_ExlBooks.AttachDispatch(m_ExlApp.GetWorkbooks(),TRUE); 
 
 //      m_ExlBook.AttachDispatch(m_ExlBooks.Add((_variant_t)TempPath),TRUE);//加载EXCEL模板 
 
       m_ExlSheets.AttachDispatch(m_ExlBook.GetSheets(),TRUE);//加载Sheet页面 
 
       //添加新的Sheet页面 
       m_ExlSheets.Add(vtMissing,vtMissing,_variant_t((long)1),vtMissing); 
 
       //删除第二个Sheet页面 
       m_ExlSheet.AttachDispatch(m_ExlSheets.GetItem(_variant_t((long)2)),TRUE); 
       m_ExlSheet.Delete(); 
 
       //把第一个Sheet页面的名字改变为TestSheet 
       m_ExlSheet.AttachDispatch(m_ExlSheets.GetItem(_variant_t((long)1)),TRUE); 
       m_ExlSheet.SetName("TestSheet"); 
 
 
       ///////合并第一行单元格A1至D1////// 
 
       //加载要合并的单元格 
       m_ExlRge.AttachDispatch(m_ExlSheet.GetRange(_variant_t("A1"),_variant_t("D1")),TRUE); 
 
       m_ExlRge.Merge(_variant_t((long)0)); 
 
       ////////设置表格内容//////// 
 
       m_ExlRge.AttachDispatch(m_ExlSheet.GetCells(),TRUE);//加载所有单元格 
 
       m_ExlRge.SetItem(_variant_t((long)1),_variant_t((long)1),_variant_t("数学系研究生课程统计")); 
 
       m_ExlRge.SetItem(_variant_t((long)2),_variant_t((long)1),_variant_t("课程名")); 
       m_ExlRge.SetItem(_variant_t((long)2),_variant_t((long)2),_variant_t("课时")); 
       m_ExlRge.SetItem(_variant_t((long)2),_variant_t((long)3),_variant_t("难度")); 
       m_ExlRge.SetItem(_variant_t((long)2),_variant_t((long)4),_variant_t("教学方式")); 
 
       m_ExlRge.SetItem(_variant_t((long)3),_variant_t((long)1),_variant_t("泛函分析")); 
       m_ExlRge.SetItem(_variant_t((long)3),_variant_t((long)2),_variant_t("60")); 
       m_ExlRge.SetItem(_variant_t((long)3),_variant_t((long)3),_variant_t("普通")); 
       m_ExlRge.SetItem(_variant_t((long)3),_variant_t((long)4),_variant_t("老师讲课")); 
 
       m_ExlRge.SetItem(_variant_t((long)4),_variant_t((long)1),_variant_t("微分流形")); 
       m_ExlRge.SetItem(_variant_t((long)4),_variant_t((long)2),_variant_t("40")); 
       m_ExlRge.SetItem(_variant_t((long)4),_variant_t((long)3),_variant_t("变态难")); 
       m_ExlRge.SetItem(_variant_t((long)4),_variant_t((long)4),_variant_t("自学")); 
 
       m_ExlRge.SetItem(_variant_t((long)5),_variant_t((long)1),_variant_t("二阶椭圆型方程与方程组")); 
       m_ExlRge.SetItem(_variant_t((long)5),_variant_t((long)2),_variant_t("60")); 
       m_ExlRge.SetItem(_variant_t((long)5),_variant_t((long)3),_variant_t("很难")); 
       m_ExlRge.SetItem(_variant_t((long)5),_variant_t((long)4),_variant_t("讨论")); 
 
 
       m_ExlRge.AttachDispatch(m_ExlSheet.GetUsedRange());//加载已使用的单元格 
 
       m_ExlRge.SetWrapText(_variant_t((long)1));//设置单元格内的文本为自动换行 
 
       //设置齐方式为水平垂直居中 
       //水平对齐:默认=1,居中=-4108,左=-4131,右=-4152 
       //垂直对齐:默认=2,居中=-4108,左=-4160,右=-4107 
       m_ExlRge.SetHorizontalAlignment(_variant_t((long)-4108)); 
       m_ExlRge.SetVerticalAlignment(_variant_t((long)-4108)); 
 
       ///////设置整体的字体、字号及颜色////// 
 
       Font ft; 
 
       ft.AttachDispatch(m_ExlRge.GetFont()); 
 
       ft.SetName(_variant_t("宋体"));//字体 
       ft.SetColorIndex(_variant_t((long)11));//字的颜色 
       ft.SetSize(_variant_t((long)12));//字号 
 
       ///////////设置标题字体及颜色////////// 
 
       m_ExlRge.AttachDispatch(m_ExlSheet.GetRange(_variant_t("A1"),_variant_t("D1"))); 
 
       ft.AttachDispatch(m_ExlRge.GetFont()); 
 
       ft.SetBold(_variant_t((long)1));//粗体 
       ft.SetSize(_variant_t((long)13)); 
       ft.SetColorIndex(_variant_t((long)2)); 
 
       CellFormat cf; 
       cf.AttachDispatch(m_ExlRge.GetCells()); 
 
       //////////////设置底色///////////////// 
 
       Interior it; 
 
       it.AttachDispatch(m_ExlRge.GetInterior()); 
 
       it.SetColorIndex(_variant_t((long)11));//标题底色 
 
       ////表格内容的底色//// 
 
       m_ExlRge.AttachDispatch(m_ExlSheet.GetRange(_variant_t("A2"),_variant_t("D5"))); 
 
       it.AttachDispatch(m_ExlRge.GetInterior()); 
 
       it.SetColorIndex(_variant_t((long)15)); 
 
 
       //////////////为表格设置边框///////////// 
 
       Range UnitRge; 
       CString CellName; 
 
       for(int i=1;i<=4;i++) 
       
              for(int j=1;j<=4;j++) 
              {     
                     CellName.Format("%c%d",j+64,i);//单元格的名称 
 
                     UnitRge.AttachDispatch(m_ExlRge.GetRange(_variant_t(CellName),_variant_t(CellName)));//加载单元格 
 
                     //LineStyle=线型 Weight=线宽 ColorIndex=线的颜色(-4105为自动) 
                     UnitRge.BorderAround(_variant_t((long)1),_variant_t((long)2),_variant_t((long)-4105),vtMissing);//设置边框 
              
       }
 
 
       //释放对象(相当重要!) 
       m_ExlRge.ReleaseDispatch(); 
       m_ExlSheet.ReleaseDispatch(); 
       m_ExlSheets.ReleaseDispatch(); 
       m_ExlBook.ReleaseDispatch(); 
       m_ExlBooks.ReleaseDispatch(); 
       //m_ExlApp一定要释放,否则程序结束后还会有一个Excel进程驻留在内存中,而且程序重复运行的时候会出错 
       m_ExlApp.ReleaseDispatch(); 
 
       //退出程序 m_ExlApp.Quit(); 

使用MFC读写Excel的更多相关文章

  1. MFC vs2012 Office2013 读写excel文件

    近期在忙一个小项目(和同学一起搞的),在这里客户要求不但读写txt,而且可以读写excel文件,这里本以为很简单,结果...废话少说,过程如下: 笔者环境:win7 64+VS2012+Office2 ...

  2. C# 使用 NPOI 库读写 Excel 文件(转载)

    NPOI 是开源的 POI 项目的.NET版,可以用来读写Excel,Word,PPT文件.在处理Excel文件上,NPOI 可以同时兼 容xls 和 xlsx.官网提供了一份Examples,给出了 ...

  3. Python3.4如何读写Excel

    在python3.x(散仙使用的版本是python3.4)里,我们应该如何操作excel. 首先在python3.4里,我们可以使用新的python类库,来支持3.x之后的读写excel 针对 03版 ...

  4. 用Python读写Excel文件(转)

    原文:google.com/ncr 虽然天天跟数据打交道,也频繁地使用Excel进行一些简单的数据处理和展示,但长期以来总是小心地避免用Python直接读写Excel文件.通常我都是把数据保存为以TA ...

  5. 使用NPOI读写Excel、Word

    NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WORD等微软OLE2组件文档的项目. 使用 NPOI 你就可以在没有安装 Office 或者相应环境的机器上对 ...

  6. 【原创】.NET读写Excel工具Spire.Xls使用(1)入门介绍

    在.NET平台,操作Excel文件是一个非常常用的需求,目前比较常规的方法有以下几种: 1.Office Com组件的方式:这个方式非常累人,微软的东西总是这么的复杂,使用起来可能非常不便,需要安装E ...

  7. 【原创】.NET读写Excel工具Spire.Xls使用(2)Excel文件的控制

                  本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html .NET读写Excel工具Spire.Xls使用文章 ...

  8. 【原创】.NET读写Excel工具Spire.Xls使用(3)单元格控制

                  本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html .NET读写Excel工具Spire.Xls使用文章 ...

  9. 【原创】.NET读写Excel工具Spire.Xls使用(4)对数据操作与控制

                  本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html .NET读写Excel工具Spire.Xls使用文章 ...

随机推荐

  1. 156 Useful Run Commands

    To Access… Run Command Accessibility Controls access.cpl Accessibility Wizard accwiz Add Hardware Wi ...

  2. UIScrollView 之图片缩放

    UIScrollView 之图片缩放 有些时候,我们可能要对某些内容进行手势缩放,如下图所示 UIScrollView不仅能滚动显示大量内容,还能对其内容进行缩放处理 也就是说,要完成缩放功能的话,只 ...

  3. Swift - 13 - 字符串和Character

    //: Playground - noun: a place where people can play import UIKit var str = "hi" // 字符串拼接 ...

  4. C#设置IP地址,启用禁用适配器

    界面效果图如下: 报表界面 说下关键代码 需要开启 Windows Management Instrumentation服务(默认已经开启),在程序中需要增加 Management引用. 主要有Net ...

  5. 【USACO 1.2.4】回文平方数

    [题目描述] 回文数是指从左向右念和从右向左念都一样的数.如12321就是一个典型的回文数. 给定一个进制B(2<=B<=20,由十进制表示),输出所有的大于等于1小于等于300(十进制下 ...

  6. Zsh安装CMake补全脚本进行CMake命令补全

    最近在尝试使用Zsh,发现其补全命令的功能相当厉害.但对CMake命令的补全在默认的5.0.5中好像没有看到,网上找了下关于配置Zsh补全的文章也没有多少.     于是自己动手,发现在Zsh安装目录 ...

  7. Java简介(1)

    起源 略. 组成 Java由四方面组成: 1.Java编程语言 2.Java文件格式 3.Java虚拟机(JVM) 4.Java应用程序接口(Java api) 体系 JavaSE , JavaEE, ...

  8. 网易DBA私享会分享会笔记2

    mysql索引与查询优化什么是索引?索引其实是一个目录.通过各种数据结构实现,是(值=>行位置)的映射 索引的作用:1.提高访问速度2.实现主键.唯一键逻辑 索引使用场景数据量特别大的时候,进行 ...

  9. 织梦DedeCms用SQL语句调用数据库任意内容

    dedecms多站点数据利用SQL句段进行互相调用数据方法:2个或者多个DEDE的站怎么互相调用数据,非JS调用,前提是2个或者多个dedecms站点都安装的同一个数据库的不同数据表内,才能实现功能. ...

  10. 9个最新的手机/移动设备jQuery插件

    随着互联网的流行,移动网站开始急速增加,在2014年手机网站将会出现很多,所以手机网站是必须要学会制作的.手机网站不像桌面平台一样制作,否则会影响显示效果,目前大部分手机网站使用响应式设计技术,而且也 ...