zoukankan      html  css  js  c++  java
  • NX二次开发-基于NX开发向导模板的NX对Excel读写操作(OLE方式(COM组件))

    在看这个博客前,请读者先去完整看完:NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))https://ufun-nxopen.blog.csdn.net/article/details/88922030 这篇博客,要不然你听不懂我下面在说什么。

    版本NX11+VS2013+office2016

    首先我们通过NX开发向导创建了一个模板。

    先把项目属性改成多字节。
    下面我们把前面做的MFC项目里的几个EXCAL头文件和stdafx一块拷过来,加到NX的项目里。

    在NX的CPP里加上#include "stdafx.h"头文件

    编译出现如下问题,把stdafx.h"头文件里的//#include "targetver.h"注释掉,在编译。

    出现 warning C4003: “CreateDialogW”宏的实参不足,双击报错问题,跳转到对应代码位置。
    把CreateDialog前加_下划线。(不要问我为什么这么做,我解释不出来),反正你在编译就通过了。同时也不当误用Block UI

    到这里这个操作EXCAL的项目搭建就完事了。
    去自己定义的回调函数里,直接写操作EXCAL的代码就行了。
    下面是打开EXCAL,读取内容的一个简单例子。写在模板的do_it里

      1     LPDISPATCH lpDisp;
      2     COleVariant vResult;
      3     COleVariant
      4         covTrue((short)TRUE),
      5         covFalse((short)FALSE),
      6         covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);
      7 
      8     if (!App.CreateDispatch("Excel.Application"))
      9     {
     10         uc1601("创建Excel实例失败", 1);
     11     }
     12 
     13 
     14     App.put_Visible(TRUE);          //使Excel可见
     15     App.put_UserControl(TRUE);
     16     App.put_DisplayAlerts(false);
     17 
     18     Books.AttachDispatch(App.get_Workbooks());
     19 
     20 
     21     //打开EXCAL
     22     lpDisp = Books.Open("D:\ABC.xlsx", covOptional, covOptional, covOptional, covOptional, covOptional, covOptional, covOptional, covOptional,
     23         covOptional, covOptional, covOptional, covOptional, covOptional, covOptional);
     24     Book.AttachDispatch(lpDisp);
     25 
     26 
     27     //得到Worksheets 
     28     lpDisp = Book.get_Worksheets();
     29     sheets.AttachDispatch(lpDisp);
     30 
     31     //获得Sheet的数量
     32     int count = sheets.get_Count();
     33 
     34     for (int k = 1; k <= count; k++)
     35     {
     36         _variant_t var = (long)k;
     37         sheet.AttachDispatch(sheets.get_Item(var));
     38 
     39         if (sheet.get_Name() == "DEF")
     40         {
     41             sheet.Activate();
     42 
     43             //获得活动的WorkSheet(工作表)
     44             sheet.AttachDispatch(Book.get_ActiveSheet(), TRUE);
     45 
     46             //获得使用的区域Range(区域)
     47             range.AttachDispatch(sheet.get_UsedRange(), TRUE);
     48 
     49             //获得使用的行数
     50             long lgUsedRowNum = 0;
     51             range.AttachDispatch(range.get_Rows(), TRUE);
     52             lgUsedRowNum = range.get_Count();
     53 
     54             //获得使用的列数
     55             long lgUsedColumnNum = 0;
     56             range.AttachDispatch(range.get_Columns(), TRUE);
     57             lgUsedColumnNum = range.get_Count();
     58 
     59             //读取Sheet名称
     60             CString strSheetName = sheet.get_Name();
     61 
     62             //得到全部Cells,此时,userRange是cells的集合
     63             range.AttachDispatch(sheet.get_Cells(), TRUE);
     64 
     65 
     66             //遍历整个Excel表格
     67             double Date1;
     68             CString str1;
     69             for (int j = 1; j <= lgUsedRowNum; j++)
     70             {
     71                 for (int i = 1; i <= lgUsedColumnNum; i++)
     72                 {
     73                     CString str;
     74                     str.Format("%c%d", 65 + i - 1, j);
     75                     lpDisp = range.get_Range(COleVariant(str), COleVariant(str));
     76 
     77                     CRange range;
     78                     range.AttachDispatch(lpDisp);
     79 
     80                     VARIANT vl = range.get_Value2();
     81 
     82 
     83                     if (vl.vt == VT_R8)       //8字节的数字
     84                     {
     85 
     86                         Date1 = vl.dblVal;
     87                         char msg[256];
     88                         sprintf_s(msg, "%f", Date1);
     89 
     90                         uc1601(msg, 1);
     91                     }
     92 
     93                     if (vl.vt == VT_BSTR)       //字符串
     94                     {
     95 
     96                         str1 = vl.bstrVal;
     97 
     98                         uc1601(str1, 1);
     99 
    100                     }
    101                 }
    102 
    103             }
    104 
    105         }
    106     }
    107 
    108 
    109 
    110     //释放对象,关闭EXCEL
    111     //range.ReleaseDispatch();
    112     //sheet.ReleaseDispatch();
    113     //sheets.ReleaseDispatch();
    114     //Book.Close(covOptional, covOptional, covOptional);
    115     //Book.ReleaseDispatch();
    116     //Books.Close();
    117     //Books.ReleaseDispatch();
    118     //App.Quit();
    119     //App.ReleaseDispatch();

    更多关于EXCAL操作代码,请大家看NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))https://www.cnblogs.com/nxopen2018/p/10981416.html 这篇文章,介绍的比较多。当前这个文章主要还是介绍怎么去搭建NX开发操作EXCAL的环境,用NX UI界面的项目,环境也是这样搭建的。

    NX二次开发CreateDialog函数在UI.hxx文件和WinUser.h中的冲突【转载】

    https://www.cnblogs.com/nxopen2018/p/11811708.html

  • 相关阅读:
    服务方式加载卸载NT驱动函数集
    《Windows核心编程》学习笔记(12)– 虚拟内存
    《Windows核心编程》学习笔记(14)– 堆
    数据库连接错误:提示TCP端口1433,sql server 2008 Connection refused:connect
    Windows驱动开发技术详解笔记
    Struts2文件上传的大小限制问题
    pragma comment的使用 pragma预处理指令详解
    解决FastCGI Error Error Number: 2147467259 (0x80004005). 和 Error Number: 1073741819 (0xc0000005).
    PHP中的日期处理
    mysql远程连接10061错误
  • 原文地址:https://www.cnblogs.com/nxopen2018/p/10981433.html
Copyright © 2011-2022 走看看