【VC++学习笔记一】MFC操作Excel
最近在做一个读取Excel的功能,之前也做过相关的,但总是零零闪闪的,趁着正在劲头上,归纳一下:
利用Automation添加相关的类,在Excel2010中可以在安装文件夹下直接点击Excel.exe 会生成很多类,建议只导入需要用到的类,不然会很卡。
用到的类和变量说明:CApplication m_ExlApp;//应用程序类,对应每一个Excel应用程序
CWorkbook wbk;//工作簿
CWorkbooks wbks;//对应每个Exel文档
CWorksheets whts ,m_Wheet;//对应每个文档的每一个sheet表
CRange range;//单元格范围,运用最广泛,获取单元格范围
ColeVarinat var;//读取每个零时变量
- 加载程序:if(!m_ExlApp.CreateDispatch("Excel.Application"))
{
AfxMessageBox("无法启动Excel服务器!");
return;
} - 连接工作簿、工作表等 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()); - 获得行高、列宽 Var = RangRow.get_RowHeight();
CString strHeight;
strHeight.Format(CString((LPCSTR)(_bstr_t)(_variant_t)Var));
float fHeight = _tstof(strHeight)*9600/7200; //转换为像素 列宽同理 - 获取单元格批注 CComment com;//批注类
com = range.get_Comment();
CString strCom = _T("");
strCom = com.Text(vtMissing,vtMissing,vtMissing); - 获取单元格是否含有边框线 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)
{//说明含有边界值,具体的可以自己查看
}
}//从左到右依次判断,并给报表的对应单元格赋值 - 获取单元格所含公式 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(); - 获取字体信息 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的更多相关文章
- VC学习笔记---ATL MFC CLR三个库的区别
MFC.ATL和CLR是VC2005内置的三大库,涵盖了Windows的各种开发方法和开发应用.当然关于C++开发的库不止这三个,不过这三个是微软推荐. 从编程所处层次而言,WIN32为最底层,其次是 ...
- 孙鑫VC学习笔记:多线程编程
孙鑫VC学习笔记:多线程编程 SkySeraph Dec 11st 2010 HQU Email:zgzhaobo@gmail.com QQ:452728574 Latest Modified ...
- VSTO学习笔记(二)Excel对象模型
原文:VSTO学习笔记(二)Excel对象模型 上一次主要学习了VSTO的发展历史及其历代版本的新特性,概述了VSTO对开发人员的帮助和效率提升.从这次开始,将从VSTO 4.0开始,逐一探讨VSTO ...
- VC学习笔记:对话框
VC学习笔记:对话框 SkySeraph NOV.11st 2009 HQU Email-zgzhaobo@gmail.com QQ-452728574 Latest Modified Date:O ...
- IOS学习笔记25—HTTP操作之ASIHTTPRequest
IOS学习笔记25—HTTP操作之ASIHTTPRequest 分类: iOS2012-08-12 10:04 7734人阅读 评论(3) 收藏 举报 iosios5网络wrapper框架新浪微博 A ...
- VC++ 学习笔记(序):神一样的语言
总的来说,我觉得VC++是一门神一样的语言——它是公认最强大.最复杂的:它一切以效率为第一要务,却又不肯落伍,拼命兼容现在的新的语言设计特点.本来在别的语言很容与就避开的问题,在这里要用很高的技巧去设 ...
- java学习笔记07--日期操作类
java学习笔记07--日期操作类 一.Date类 在java.util包中定义了Date类,Date类本身使用非常简单,直接输出其实例化对象即可. public class T { public ...
- jQuery学习笔记之DOM操作、事件绑定(2)
jQuery学习笔记之DOM操作.事件绑定(2) --------------------学习目录------------------------ 4.DOM操作 5.事件绑定 源码地址: https ...
- tensorflow学习笔记——使用TensorFlow操作MNIST数据(2)
tensorflow学习笔记——使用TensorFlow操作MNIST数据(1) 一:神经网络知识点整理 1.1,多层:使用多层权重,例如多层全连接方式 以下定义了三个隐藏层的全连接方式的神经网络样例 ...
- tensorflow学习笔记——使用TensorFlow操作MNIST数据(1)
续集请点击我:tensorflow学习笔记——使用TensorFlow操作MNIST数据(2) 本节开始学习使用tensorflow教程,当然从最简单的MNIST开始.这怎么说呢,就好比编程入门有He ...
随机推荐
- oracle 登录
命令行登录 sql plus登录 plsql登录 自己电脑登录 既然是登录自己电脑的数据库,肯定是已经安装过了oralce,而且已经创建了数据库等等. 局域网登录 1.必须安装oracleclient ...
- [javase学习笔记]-7.6 thiskeyword的原理
这一节我们来讲一个keyword.就是thiskeyword. 我们还是通过样例来看吧: class Person { private String name; private int age; Pe ...
- 蓝牙压力測试报抛android.os.TransactionTooLargeException异常分析总结
1.从main日志中找到异常点,例如以下: 08-20 11:05:19.754 5023 5023 E AndroidRuntime: FATAL EXCEPTION: main 08-20 11: ...
- git ---- 产生冲突的场景 和解决办法
1.git冲突的场景 情景一:多个分支代码合并到一个分支时: 情景二:多个分支向同一个远端分支推送代码时: 实际上,push操作即是将本地代码merge到远端库分支上. 关于push和pull其实就分 ...
- 6.deque
#include <iostream> #include <deque> #include <algorithm> using namespace std; //序 ...
- 用@property (copy) NSMutableArray *array;会有什么问题?
我们县回忆一下copy属性的作用,一个属性标记了copy,当你调用他的setter方法,他会建立一个索引计数为1的对象,然后释放旧对象. @property (copy) NSMutableArray ...
- 3、Go Exit
package main import ( "fmt" "os") func main() { //当使用`os.Exit`的时候defer操作不会被运行 所以 ...
- CSS 制作 圆角TAB选项卡下拉效果(顺便学习CSS伪元素
CSS伪元素: 伪元素如果没有设置“content”属性,伪元素是无用的. 使用伪元素插入的内容在页面的源码里是不可见的,只能在css里可见 插入的元素在默认情况下是内联元素(或者,在html5中,在 ...
- CF GYM 100781A(菊花图+直径)
题目大意 给出若干颗树用最少的边把它们连成一个无向连通图,同时使图的直径最小.输出最小直径. 题解 我们定义树的半径为(树的直径+1)/2.符合题意的连接方式为.所有树的“中点”连在直径最长的树的中点 ...
- Linux 中挂载 ISO 文件
在 Linux 中挂载 ISO 文件 用 mount 命令,在终端中输入如下命令即可: sudo mount -o loop filename.iso /cdrom 其中 filename.iso 是 ...