NX二次开发API里没有对EXCAL读写操作的相关函数,市面上有很多种方法去实现,比如UFUN调KF,ODBC,OLE(COM组件)等等。这里我是用的OLE(COM组件)方式去做的,这种在VC上创建的方法,无论C++还是C#还是VB方式思路都是一样的。先介绍用MFC去做,然后在写一篇博客介绍怎么在NX的二次开发的向导模板里去做。
NX二次开发-基于NX开发向导模板的NX对Excel读写操作(OLE方式(COM组件))https://ufun-nxopen.blog.csdn.net/article/details/88922238 (再看这篇博客前,先把当前博客看完。)
版本:VS2013 office2016

图片转载自https://blog.csdn.net/xiaoxiangyuan123456/article/details/70941588, 感谢博主。

  • EXCAL操作(一)打开写入

参考例子:https://blog.csdn.net/ywx123_/article/details/77074038
这是另一个CSDN博主写的,我也是参考他的例子去做的,再此感谢这位博主。

新建一个MFC项目

点击下一步

选择基于对话框

直接点完成,进来后如下图

先点项目,右键属性,更改为多字节。

先什么都不动,编译一下代码。默认看能不能通过。
然后点项目,右键类向导。

弹出窗口如下

点击添加类-类型库中的MFC类

弹出如下

我们切换到文件,点击添加。

此处添加要找到的文件就是你电脑上装的EXCAL.exe这个程序文件。
如果你不知道怎么找到的话,有一个方法,先去开始菜单找到你的EXCAL快捷方式,然后在点右键,打开文件所在的位置。

这样就找到了。

下面在回到MFC项目里面,我们选中这个文件。
添加进来之后,如图所示。

左侧为EXCAL给出的接口,我们来选择一些需要的添加进来。
我们就先添加这七个,后续有其他需求在添加其他的。(先在左侧接口里选中一个,点中间的>就能添加到右侧里生成的类里,不想要就在点中间的<撤退回去。)

然后我们点完成,点确定。就看到头文件自动添加进来了。

我们点击新增进来的EXCAL每个头文件,都把第一行的那句注释掉。

都注释完之后,我们在#include "stdafx.h"里添加EXCAL头文件,

然后编译代码,出现如下报错问题。这时我们双击这个错误,跳到对应的代码那里。

有问题的位置如下

我们需要在DialogBox前面加上一个 _ 下划线。再去编译就通过了。别问我为什么,我答不上来,你照着搞就是了,别人就是这么搞的。

好的,到这里我们这个项目环境就算搭建完成了。
下面可以写代码了。
点击MFC那个对话框界面,双击确定。在里面写代码。

代码如下:打开EXCAL,写入内容。

     //1.创建基本对象
CApplication App; //创建应用程序实例
CWorkbooks Books; //工作簿,多个Excel文件
CWorkbook Book; //单个工作簿
CWorksheets sheets;//多个sheet页面
CWorksheet sheet; //单个sheet页面
CRange range; //操作单元格
//2.打开指定Excel文件,如果不存在就创建
char path[MAX_PATH];
GetCurrentDirectory(MAX_PATH, (TCHAR*)path);//获取当前路径
CString strExcelFile = (TCHAR*)path;
CString strdevName = _T("\\Test.xlsx"); //xls也行
strExcelFile += strdevName;
COleVariant
covTrue((short)TRUE),
covFalse((short)FALSE),
covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR); LPDISPATCH lpdisp = NULL;
//1.创建Excel实例
if (!App.CreateDispatch(_T("Excel.Application"), NULL))
{
AfxMessageBox(_T("创建Excel实例失败"));
exit(-);
}
else
{
AfxMessageBox(_T("创建成功"));
}
App.put_Visible(TRUE); //打开Excel
App.put_UserControl(FALSE);
//2. 得到workbooks容器
Books.AttachDispatch(App.get_Workbooks());
Book.AttachDispatch(Books.Add(covOptional));
sheets.AttachDispatch(Book.get_Worksheets());
sheet.AttachDispatch(sheets.get_Item(COleVariant((short)))); //获取sheet1
sheet.put_Name(_T("TestName")); //设置sheet1名字 //3. 加载要合并的单元格
range.AttachDispatch(sheet.get_Range(COleVariant(_T("B2")), COleVariant(_T("E2"))), TRUE);
range.Merge(COleVariant((long))); //合并单元格 //4. 设置表格内容
range.AttachDispatch(sheet.get_Cells(), TRUE); //加载所有单元格
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("电气工程及其自动化课程统计")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("课程名称")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("课时")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("难度")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("教学方式"))); range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("电磁场")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("变态难")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("老师讲课"))); range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("电机学")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("难")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("老师讲课加实验"))); range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("PLC")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("普通")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("老师讲课加实验"))); range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("电力系统")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("难")));
range.put_Item(COleVariant((long)), COleVariant((long)), COleVariant(_T("老师讲课加实验"))); range.AttachDispatch(sheet.get_UsedRange());//加载已使用的单元格
range.put_WrapText(COleVariant((long))); //设置文本自动换行 //5.设置对齐方式
//水平对齐:默认 1 居中 -4108, 左= -4131,右=-4152
//垂直对齐:默认 2 居中 -4108, 左= -4160,右=-4107
range.put_VerticalAlignment(COleVariant((long)-));
range.put_HorizontalAlignment(COleVariant((long)-));
//6.设置字体颜色
CFont0 ft;
ft.AttachDispatch(range.get_Font());
ft.put_Name(COleVariant(_T("楷体"))); //字体
ft.put_ColorIndex(COleVariant((long)));//颜色 //黑色
ft.put_Size(COleVariant((long))); //大小 range.AttachDispatch(sheet.get_Range(COleVariant(_T("B2")), COleVariant(_T("E2"))), TRUE);
ft.AttachDispatch(range.get_Font());
ft.put_Name(COleVariant(_T("华文行楷")));
ft.put_Bold(COleVariant((long)));
ft.put_ColorIndex(COleVariant((long))); //颜色
ft.put_Size(COleVariant((long))); //大小
Book.SaveCopyAs(COleVariant(strExcelFile)); //保存 Book.put_Saved(TRUE);
//8.释放资源
range.ReleaseDispatch();
sheet.ReleaseDispatch();
sheets.ReleaseDispatch();
Book.ReleaseDispatch();
Books.ReleaseDispatch();
App.ReleaseDispatch();

编译后,我们点调试-开始执行。

点确定,自动打开了EXCAL,并写入了内容。EXCAL自动保存在了你这个项目的当前文件夹里。

就写到这里了,好多我也没有用过,回头用到了再去研究。其他的相关内容大家参考下面这些大神们的博客吧。
参考资料:
一个封装的实用的EXCEL类 https://blog.csdn.net/gyssoft/article/details/1592104
vs对Excel读写操作 https://blog.csdn.net/qq_16334327/article/details/81353248
在 VS2008 下操作 Excel 的方法总结 https://blog.csdn.net/DavidHsing/article/details/4231592
VS2010 对Excel读写操作 https://blog.csdn.net/ywx123_/article/details/77074038
VS2010 MFC Excel(1)https://www.cnblogs.com/zztong/p/6695283.html
VS2010 MFC 读取Excel(2)https://www.cnblogs.com/zztong/p/6695284.html
VS2010对Excel2010进行操作 https://blog.csdn.net/xiaoxiangyuan123456/article/details/70941588
(转)VS2010 MFC 操作Excel(读写)https://blog.csdn.net/zhaodan19861107/article/details/80675888
VS2010 MFC读取Excel文件中数据 https://blog.csdn.net/V10_x/article/details/78464453
MFC vs2012 Office2013 读写excel文件(OLE/COM)https://blog.csdn.net/baidu_37503452/article/details/72842573
vs创建控制台程序使用C++读写excel文件(ODBC方式)https://www.cnblogs.com/renjiashuo/p/7545784.html
VC++遍历Excelhttps://blog.csdn.net/z3312656/article/details/8282194
感谢各位大神无私的奉献。

NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))的更多相关文章

  1. NX二次开发-基于NX开发向导模板的NX对Excel读写操作(OLE方式(COM组件))

    在看这个博客前,请读者先去完整看完:NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))https://ufun-nxopen.blog.csdn.net/article ...

  2. NX二次开发-基于MFC界面对话框与NX交互的开发

    打开VS2013 点击新建,选择MFC DLL 点击确定 点下一步 什么都不改,直接点完成 进来之后先编译一下,看是否编译成功 打开项目属性,更改这几处 $(UGII_BASE_DIR)\ugopen ...

  3. NX二次开发-使用MFC对话框不能用UF_UI_select等函数解决方法

    VC/MFC调用UG Dialog要进入加锁状态 加锁 UF_UI_lock_ug_access ( UF_UI_FROM_CUSTOM ); 此处为UF_UI_select的函数 解锁 UF_UI_ ...

  4. NX二次开发-UFUN获取显示在NX交互界面的对象UF_OBJ_is_displayable

    NX9+VS2012 #include <uf.h> #include <uf_disp.h> #include <uf_obj.h> #include <u ...

  5. NX二次开发-bat脚本文件切换NX的环境变量(NX路径和语言)

    路径环境变量切换到NX9.bat @echo off setx /M UGII_BASE_DIR "D:\Program Files\Siemens\NX 9.0" ------- ...

  6. NX二次开发-OLE/COM向EXCEL表格中插入图片

    今晚有一个兄弟问我怎么往EXCEL里插入图片(加工程序单中需要插入图片),这个我之前也没弄过,回复了他一句不知道,后来刚刚干完游戏吃完鸡,就去VC++的书上翻了翻,还真的被我翻到了.VC++的方法往E ...

  7. NX二次开发-创建(临时)坐标系

    函数:UF_CSYS_create_csys() . UF_CSYS_create_temp_csys() 函数说明:创建坐标系 .创建临时坐标系 用法: #include <uf.h> ...

  8. 【NX二次开发】多种变换

    变换的种类: uf5942 矩阵乘积变换 uf5943 平移变换 uf5944 缩放变换 uf5945 旋转变换 uf5946 镜像变换 最后使用 uf5947 实现uf5942-uf5946的变换. ...

  9. NX二次开发-BlockUI对话框嵌套MFC对话框制作进度条

    半年前在一些QQ群看到有大神NX二次开发做出了进度条,那个时候我还不会弄,也不知道怎么弄得,后来断断续续得研究了一下,直到今天我把它做出来了.内心还是很喜悦的!回想自己这两年当初从没公司肯给我做NX二 ...

随机推荐

  1. eclipse开发安卓 发短信打电话发送邮件功能

    1.在mainfiest中添加   //添加拨打电话的功能    <uses-permission android:name="android.permission.CALL_PHON ...

  2. jq实现跟随鼠标点击移动的下划线效果

    效果如下: 1.html代码: <div class="center-left-tap"> <a href="javascript:void (0)&q ...

  3. mysql授权、删除用户和角色权限

    备份权限 GRANT USAGE ON *.* TO 'backup'@'172.16.0.157' IDENTIFIED BY PASSWORD '*38B4F16EADB1601E713D9F03 ...

  4. [六省联考2017]分手是祝愿 题解(期望dp)

    题目描述 B 君在玩一个游戏,这个游戏由 n 个灯和 n 个开关组成,给定这 n 个灯的初始状态,下标为从 1 到 n 的正整数. 每个灯有两个状态亮和灭,我们用 1 来表示这个灯是亮的,用 0 表示 ...

  5. [NOIP模拟测试31]题解

    A.math 考场乱搞拿了95,2333. 考虑裴蜀定理:$ax+by=z$存在整数解,当且仅当$gcd(a,b)|z$. 那么如果某个数能够被拼出来,就必须满足所有$a_i$的$gcd$是它的因子. ...

  6. 2018icpc沈阳/gym101955 J How Much Memory Your Code Is Using? 签到

    题意: 给你定义一堆变量,计算一下这些变量共占了多少k内存. 题解: 按题意模拟即可,善用ceil() // // Created by melon on 2019/10/22. // #includ ...

  7. HTML-参考手册: HTML 符号实体

    ylbtech-HTML-参考手册: HTML 符号实体 1.返回顶部 1. HTML 符号实体 本字符实体参考手册包括了数学符号.希腊字符.各种箭头记号.科技符号以及形状. 注释: 实体名称对大小写 ...

  8. cs224d 作业 problem set2 (二) TensorFlow 实现命名实体识别

    神经网络在命名实体识别中的应用 所有的这些包括之前的两篇都可以通过tensorflow 模型的托管部署到 google cloud 上面,发布成restful接口,从而与任何的ERP,CRM系统集成. ...

  9. 基于MFC的Media Player播放器的制作(1---播放器界面的布局)

    |   版权声明:本文为博主原创文章,未经博主允许不得转载. 通过上面的一些预备知识,我们现在就可以自己来制作基于MFC的播放器了,接下来我们讲的是使用MFC制作我们播放器 的界面. 首先,我们我们打 ...

  10. spark性能调优02-JVM调优

    1.降低cache操作的内存占比 1.1 为什么要降低cache操作的内存占比 spark的堆内存分别两部分,一部分用来给Rdd的缓存进行使用,另一部分供spark算子函数运行使用,存放函数中的对象 ...