转载-NX11.0二次开发新增Spreadsheet相关类的用法!
这几天搜NX对EXCAL读取写入相关的开发内容,发现唐工写了一篇关于NX11对EXCAL操作的文章。让我知道NX11新增了对EXCAL操作相关的类,以前NX里是没有的。我以前都是用OLE方式去做,没用过其他的,今天学习一下。感谢唐工的分享。
原文出处:http://www.ugsnx.com/thread-167024-1-1.html
ps:经过多次测试,这种方式有一个缺点,就是写入的时候不能覆盖写入,新内容只能接原来的内容继续写。
在 NX11中,新增了与电子表格操作的类;
Spreadsheet
SpreadsheetCellData
SpreadsheetExternal
SpreadsheetManager
对应的头文件为:
#include <NXOpen/Spreadsheet.hxx>
#include <NXOpen/SpreadsheetCellData.hxx>
#include <NXOpen/SpreadsheetExternal.hxx>
#include <NXOpen/SpreadsheetManager.hxx> ```
利用这些类,可以操作内部与外部的电子表格。
我写了一个例子:
、新建电子表格;
、然后写入不同的数据;
、再读取相关内容,打印在信息窗口;
注:个人感觉NX11虽然增加了这些类,但读取的效率比较低下,还没有用UFUN调KF的方法来读写电子表格效率高。 ```c
void MyClass::do_it()
{
UF_initialize();
//创建电子表格
************************ //打开
NXOpen::SpreadsheetExternal *openfile=
theSession->SpreadsheetManager()->OpenFile("c:\\tkl.xls", NXOpen::SpreadsheetManager::OpenModeWrite);
int worksheet = openfile->GetWorksheetIndex("tkl"); //得到电子表格工作页 //在A1-c1中写入数字
std::vector<NXOpen::SpreadsheetCellData *> addata;
for (size_t i = ; i < ; i++)
{
NXOpen::SpreadsheetCellData *celldata = theSession->SpreadsheetManager()->CreateCellData();
celldata->SetType(NXOpen::SpreadsheetCellData::TypesInt);
celldata->SetIntValue((int)i+);
addata.push_back(celldata);
}
openfile->AppendRow(worksheet, addata);
addata.clear(); //在A2-D2中写入字符串
std::ostringstream tempnumberstring;
for (size_t i = ; i < ; i++)
{
NXOpen::SpreadsheetCellData *celldata = theSession->SpreadsheetManager()->CreateCellData();
celldata->SetType(NXOpen::SpreadsheetCellData::TypesString);
tempnumberstring << i+;
std::string covertvalue = tempnumberstring.str();
celldata->SetStringValue("字符" + covertvalue);
addata.push_back(celldata);
tempnumberstring.str("");
tempnumberstring.clear();
}
openfile->AppendRow(worksheet, addata);
addata.clear(); //在A3-C3中写入布尔型
for (size_t i = ; i < ; i++)
{
NXOpen::SpreadsheetCellData *celldata = theSession->SpreadsheetManager()->CreateCellData();
celldata->SetType(NXOpen::SpreadsheetCellData::TypesLogical);
if ((int)i==)
{
celldata->SetLogicalValue(true);
}
else
{
celldata->SetLogicalValue(false);
}
addata.push_back(celldata);
}
openfile->AppendRow(worksheet, addata);
addata.clear(); //读取
std::vector<NXOpen::SpreadsheetCellData *> thedata;
openfile->ReadRange(worksheet, -, -, -, -, thedata); //读取范围,
//打印基本信息
theSession->ListingWindow()->Open();
std::ostringstream tempstring;
tempstring << "表序号:" << thedata[]->IntValue() << ",起始行:" << thedata[]->IntValue() << ",起始列:"
<< thedata[]->IntValue() << ",结束行:" << thedata[]->IntValue() << ",结束列:" << thedata[]->IntValue();
std::string covertvalue = tempstring.str();
theSession->ListingWindow()->WriteFullline(covertvalue);
tempstring.str("");
tempstring.clear(); //打印每个单元格详细信息
for (size_t i = ; i < (int)thedata.size(); i++)
{
NXOpen::SpreadsheetCellData::Types thetype = thedata[i]->Type();
if (thetype == SpreadsheetCellData::TypesInt)
{
tempstring << thedata[i]->IntValue() << ",";
}
else if (thetype == SpreadsheetCellData::TypesDouble)
{
tempstring << thedata[i]->DoubleValue() << ",";
}
else if (thetype == SpreadsheetCellData::TypesString )
{
tempstring << thedata[i]->StringValue().GetLocaleText() << ",";
}
else if (thetype == SpreadsheetCellData::TypesLogical)
{
tempstring << thedata[i]->LogicalValue() << ",";
}
else
{
tempstring << thedata[i]->FormulaValue().GetLocaleText() << ",";
} if ((i - ) % (thedata[]->IntValue() - thedata[]->IntValue() + ) == )
{
std::string covertvalue = tempstring.str();
theSession->ListingWindow()->WriteFullline(covertvalue);
tempstring.str("");
tempstring.clear();
}
} //关闭电子表格并保存
openfile->CloseFile(true); UF_terminate();
}

转载-NX11.0二次开发新增Spreadsheet相关类的用法!的更多相关文章
- scratch3.0二次开发scratch3.0基本介绍(第一章)
为什么要自己开发而不使用官方版本? 这个问题要看我们的做少儿编程教育的需求是怎么样的. scratch本身提供了离线版本以及官网在线平台供我们使用,这足以满足我们对于编程教学模块的需求.但是对于一些教 ...
- 17 win7 sp1 x64/VS2015下配置creo4.0二次开发环境——调用了众多开源库(ceres-solver,PCL1.8.0,office 2016COM接口,MySql数据库等)
0 引言 本次开发环境的配置是在综合考虑了开源库的版本.VS版本以及CREO4.0的版本,同时针对甲方需求选择了win7 sp1 x64系统. 配置的过程中遇到了形形色色的问题,但是一一解决了.通过这 ...
- NX二次开发-UFUN发射线函数UF_MODL_trace_a_ray的用法
今天是国庆节,放假休息懒得动,没有出去玩,在家研究一下发射线函数UF_MODL_trace_a_ray.小弟以前在软件公司混的时候,当时我做的那个项目就用到了UF_MODL_trace_a_ray,当 ...
- android 6.0 SDK中删除HttpClient的相关类的解决方法
一.出现的情况 在eclipse或 android studio开发, 设置android SDK的编译版本为23时,且使用了httpClient相关类的库项目:如android-async-http ...
- CRMEB小程序商城v4.0二次开发对接集成阿里云短信
作者:廖飞 - CRMEB小程序商城研发项目组长 前言 cremb小程序商城v4.0版本支持短信平台为云信,但有部分用户有需求对接阿里云短信,这篇文章将对阿里云短信平台如何对接方以及对接流程详细说明. ...
- TinkPHP框架开发的CRMEB小程序商城v4.0二次开发集成支付宝支付
前言 大家都知道支付宝支付和微信支付宝都只能局限在自己的平台,微信内支付宝支付是根本就不能使用,即使是公众号支付也需要跳转到外部浏览器才可以唤起支付宝支付,并且QQ浏览器唤起支付宝支付还是问题很多,所 ...
- IDEA 编译 Jmeter 4.0 ( 二次开发_1 )
IDEA 编译 Jmeter 下载 http://jmeter.apache.org/download_jmeter.cgi 下载源码后解压『Jmeter』,我这边下载的是最新的『apache-jme ...
- IDEA 编译 Jmeter 5.0(二次开发)
windows10 操作系统,jdk1.8,Intellij IDEA 2018,jmeter5.0 1.下载 http://jmeter.apache.org/download_jmeter.cgi ...
- JMeter4.0二次开发之导入eclipse
1.先建立工程,命名为JMeter4.0. JDK版本为10.0.1 2.在官网下载src文件,通过文件系统导入到JMeter4.0工程中 3.在ant中选择download_jars,ant会自动下 ...
随机推荐
- 洛谷P2015 二叉苹果树(树状dp)
题目描述 有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点) 这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1. 我们用一根树枝两端连接的结点的编号来 ...
- 【Linux】【sendmail】利用sendmail发送带附件的邮件及解决邮件中文标题乱码
#收件邮箱列表 TO_LIST=$1 #邮件标题 MAIL_TITLE=$2 #附件地址 LOG_PATH=$3 fromAdd="=?UTF-8?B?`echo $MAIL_TITLE | ...
- Vue - 前端本地项目开发过程中webpack打包内存泄漏问题解决方法
编译项目出现如下错误: FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 原因: n ...
- centos6 sersync2使用
接收端rsyncd搭建 http://www.cnblogs.com/hanxiaohui/p/8675409.html 推送端sersync2使用 安装 源码包D:\share\src\sersyn ...
- activemq学习总结 (转)Java消息队列--ActiveMq 实战
转:https://www.cnblogs.com/jaycekon/p/6225058.html 感谢作者 ActiveMQ官网下载地址:http://activemq.apache.org/dow ...
- 服务安全-OAuth-OAuth2.0:百科
ylbtech-服务安全-OAuth-OAuth2.0:百科 OAuth2.0是OAuth协议的延续版本,但不向后兼容OAuth 2.0即完全废止了OAuth1.0. OAuth 2.0关注客户端开发 ...
- WebBrowser是IE内置的浏览器控件
WebBrowser是IE内置的浏览器控件.WebBrowser是IE内置的浏览器控件.WebBrowser是IE内置的浏览器控件.重要的事情说三遍,原因是一开始使用的时候就在这踩了坑. WebBro ...
- 【C++第一个Demo】---控制台RPG游戏4【角色系统】
[角色基类] #ifndef _ROLE_H_ #define _ROLE_H_ #include<list> #include<vector> #include " ...
- Mysql任意读取客户端文件复现
本机执行 python rogue_mysql_server.py 目标机器上连接本机数据库 mysql -u root -p -h 本机IP mysql -h 192.168.250.132 -ur ...
- apache2.2.25+tomcat7.0.47集群方案
因为公司项目在线人数的增加,随着现在硬件成本越来越低,大多数的生产环境内存大多都已经达到 16G,尤其最新的阿里云,客户的机器都是配置超高的java主机,但是Java的运行环境,内存使用有限 ,这样就 ...