最近在做一个读取Excel的功能,之前也做过相关的,但总是零零闪闪的,趁着正在劲头上,归纳一下:

利用Automation添加相关的类,在Excel2010中可以在安装文件夹下直接点击Excel.exe 会生成很多类,建议只导入需要用到的类,不然会很卡。

用到的类和变量说明:CApplication m_ExlApp;//应用程序类,对应每一个Excel应用程序

CWorkbook wbk;//工作簿
                                  CWorkbooks wbks;//对应每个Exel文档

CWorksheets whts ,m_Wheet;//对应每个文档的每一个sheet表
                                  CRange range;//单元格范围,运用最广泛,获取单元格范围
                                  ColeVarinat var;//读取每个零时变量

  1. 加载程序:if(!m_ExlApp.CreateDispatch("Excel.Application"))
                            {
                                  AfxMessageBox("无法启动Excel服务器!");
                                  return;
                            }
  2. 连接工作簿、工作表等      COleVariant  avar((long)DISP_E_PARAMNOTFOUND,VT_ERROR);
                                      m_ExlApp.put_Visible(TRUE);//使Excel可见
                                      m_ExlApp.put_UserControl(TRUE);//允许其它用户控制Excel,否则Excel将一闪即逝.
                                      wbks.AttachDispatch(m_ExlApp.get_Workbooks());
                                      wbk =wbks.Open(m_StrExcelPath,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar);
                                      whts = wbk.get_Sheets();
                                      m_Wheet = whts.get_Item(_variant_t((short)1));
                                      range.AttachDispatch(m_Wheet.get_UsedRange());
  3. 获得行高、列宽   Var = RangRow.get_RowHeight();
                           CString strHeight;  
                           strHeight.Format(CString((LPCSTR)(_bstr_t)(_variant_t)Var));
                           float fHeight = _tstof(strHeight)*9600/7200;  //转换为像素  列宽同理
  4. 获取单元格批注   CComment com;//批注类
                          com = range.get_Comment();    
                          CString strCom = _T("");
                          strCom = com.Text(vtMissing,vtMissing,vtMissing);
  5. 获取单元格是否含有边框线  CRange RCellBorder;
                                       CBorders BCellBorders;
                                       CBorder BCellBorder;
                                       COleVariant varBorderInfo;
                                       RCellBorder.AttachDispatch(m_Wheet.get_Cells());
                                       RCellBorder.AttachDispatch(RCellBorder.get_Item(COleVariant(nRow),COleVariant(nCol)).pdispVal);
                                       BCellBorders = RCellBorder.get_Borders();
                                       for (long i = 7;i < 11;i++)
                                       {//Left:7 Top:8 Bottom:9 Right 10
                                            BCellBorder = BCellBorders.get_Item(i);
                                            varBorderInfo = BCellBorder.get_LineStyle();
                                             if (-4142 != varBorderInfo.lVal)
                                             {//说明含有边界值,具体的可以自己查看                                            
                                             }
                                        }//从左到右依次判断,并给报表的对应单元格赋值
  6. 获取单元格所含公式       CRange RFormula;
                                    COleVariant varFormula;
                                    CString strFormula = _T("");
                                    RFormula.AttachDispatch(m_Wheet.get_Cells());
                                    RFormula.AttachDispatch(RFormula.get_Item(COleVariant(nRow),COleVariant(nCol)).pdispVal);
                                    varFormula = RFormula.get_Formula();
                                    strFormula = varFormula.bstrVal;
                                    if (0 != strFormula.CompareNoCase(""))
                                   {
                                    }
                                    RFormula.ReleaseDispatch();
  7. 获取字体信息               LOGFONT *pLogFont = NULL; 字体信息存放在这个指针中
                                    CFont0 fTextFont;
                                   CRange RTextFont;
                                   COleVariant varFontInfo;
                                   RTextFont.AttachDispatch(m_Wheet.get_Cells());
                                   RTextFont.AttachDispatch(RTextFont.get_Item(COleVariant(nRow),COleVariant(nCol)).pdispVal);
                                   fTextFont = RTextFont.get_Font();
                                   pCell = (CGridCell*)m_npGridCtrl->GetCell(nRow,nCol);//获取原有单元格的字体
                                   pLogFont = pCell->GetFont();

    //字体名称
                                  varFontInfo = fTextFont.get_Name();
                                  CString strFontName(varFontInfo.bstrVal);
                                  strcpy(pLogFont->lfFaceName,strFontName);

    //字体高度
                                  varFontInfo = fTextFont.get_Size();
                                  double dHeight = abs(varFontInfo.dblVal * 96/72);
                                  pLogFont->lfHeight = long(dHeight);

    //加粗
                                 varFontInfo = fTextFont.get_Bold();
                                  if (varFontInfo.boolVal)
                                 {
                                       pLogFont->lfWeight = 700;
                                 }

    //斜体
                                varFontInfo = fTextFont.get_Italic();
                                if (varFontInfo.boolVal)
                                {
                                   pLogFont->lfItalic = TRUE;
                                 }

    //下划线 读出单下滑线与多下划线
                                varFontInfo = fTextFont.get_Underline();
                                long lUnderLine = varFontInfo.lVal;
                                if (-4119 == lUnderLine || 2 == lUnderLine)
                               {
                                   pLogFont->lfUnderline = TRUE;
                               }

//第一次写这样的博客,记录学习笔记,成为优秀的程序员,终有一天,我要站在巨人的肩上!

【VC++学习笔记一】MFC操作Excel的更多相关文章

  1. VC学习笔记---ATL MFC CLR三个库的区别

    MFC.ATL和CLR是VC2005内置的三大库,涵盖了Windows的各种开发方法和开发应用.当然关于C++开发的库不止这三个,不过这三个是微软推荐. 从编程所处层次而言,WIN32为最底层,其次是 ...

  2. 孙鑫VC学习笔记:多线程编程

    孙鑫VC学习笔记:多线程编程 SkySeraph Dec 11st 2010  HQU Email:zgzhaobo@gmail.com    QQ:452728574 Latest Modified ...

  3. VSTO学习笔记(二)Excel对象模型

    原文:VSTO学习笔记(二)Excel对象模型 上一次主要学习了VSTO的发展历史及其历代版本的新特性,概述了VSTO对开发人员的帮助和效率提升.从这次开始,将从VSTO 4.0开始,逐一探讨VSTO ...

  4. VC学习笔记:对话框

    VC学习笔记:对话框 SkySeraph NOV.11st 2009 HQU Email-zgzhaobo@gmail.com  QQ-452728574 Latest Modified Date:O ...

  5. IOS学习笔记25—HTTP操作之ASIHTTPRequest

    IOS学习笔记25—HTTP操作之ASIHTTPRequest 分类: iOS2012-08-12 10:04 7734人阅读 评论(3) 收藏 举报 iosios5网络wrapper框架新浪微博 A ...

  6. VC++ 学习笔记(序):神一样的语言

    总的来说,我觉得VC++是一门神一样的语言——它是公认最强大.最复杂的:它一切以效率为第一要务,却又不肯落伍,拼命兼容现在的新的语言设计特点.本来在别的语言很容与就避开的问题,在这里要用很高的技巧去设 ...

  7. java学习笔记07--日期操作类

    java学习笔记07--日期操作类   一.Date类 在java.util包中定义了Date类,Date类本身使用非常简单,直接输出其实例化对象即可. public class T { public ...

  8. jQuery学习笔记之DOM操作、事件绑定(2)

    jQuery学习笔记之DOM操作.事件绑定(2) --------------------学习目录------------------------ 4.DOM操作 5.事件绑定 源码地址: https ...

  9. tensorflow学习笔记——使用TensorFlow操作MNIST数据(2)

    tensorflow学习笔记——使用TensorFlow操作MNIST数据(1) 一:神经网络知识点整理 1.1,多层:使用多层权重,例如多层全连接方式 以下定义了三个隐藏层的全连接方式的神经网络样例 ...

  10. tensorflow学习笔记——使用TensorFlow操作MNIST数据(1)

    续集请点击我:tensorflow学习笔记——使用TensorFlow操作MNIST数据(2) 本节开始学习使用tensorflow教程,当然从最简单的MNIST开始.这怎么说呢,就好比编程入门有He ...

随机推荐

  1. BZOJ 2424 DP OR 费用流

    思路: 1.DP f[i][j]表示第i个月的月底 还剩j的容量 转移还是相对比较好想的-- f[i][j+1]=min(f[i][j+1],f[i][j]+d[i]); if(j>=u[i+1 ...

  2. Visual Studio添加lib到链接依赖项的几种方法

    使用第三方库文件编写应用时经常会出现链接错误: 错误 22 error LNK2019: 无法解析的外部符号..... 该符号在函数.....在....中被引用 出现这个错误的原因很简单,链接器在將库 ...

  3. PostgreSQL中流复制pg_basebackup做了什么

    解压PostgreSQL源代码包后可以到如下路径:postgresql-9.2.4\src\backend\replication下可以看到,basebackup.c,另外还可以看到walreceiv ...

  4. 十一 模板匹配match template

    一.介绍 1.模板匹配 通俗讲就是以图找图,通过图中的一部分来找它在图中的位置(模板匹配就是在整个图像区域发现与给定子图像匹配的小块区域). 模板匹配是一种最原始.最基本的模式识别方法,研究某一特定对 ...

  5. 冒泡排序php

    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" /> <b ...

  6. PHP实现杨辉三角形

    <?php /**** * 杨辉三角形:我的实现方式. * 下标 * 1 0 * 1 1 1 循环上一行数据1次,计算后结果追加到当前行末尾 * 1 2 1 2 * 1 3 3 1 3 * 1 ...

  7. 测试cnblog文章内部JS

    添加几个按钮 行内js 写法: <button onclick="javascript:alert('行内js')">行内js</button> 注意:al ...

  8. 用树链剖分来写LCA

    当两个点在一条链上,它们的LCA就是深度较小的那个点. 于是这种树链剖分写LCA的思想就是把要求的两个点想办法靠到一条链上. 而且要靠到尽量更优的一条链上(重链). 做法: 预处理出每棵树上的重链(s ...

  9. 推荐《R数据可视化手册》高清英文版PDF+中文版PDF+源代码

    绝大多数的绘图案例都是以强大.灵活制图而著称的R包ggplot2实现的,充分展现了ggplot2生动.翔实的一面.从如何画点图.线图.柱状图,到如何添加注解.修改坐标轴和图例,再到分面的使用和颜色的选 ...

  10. info---Linux下info格式的帮助指令。

    info命令是Linux下info格式的帮助指令. 它的几个常用快捷键. ?键:它就会显示info的常用快捷键. N键:显示(相对于本节点的)下一节点的文档内容. P键:显示(相对于本节点的)前一节点 ...