PLM之家PLMHome-工业软件与AI结合践行者

Teamcenter二次开发实例教程-报表开发教程

  [复制链接]

2019-7-10 18:59:24 12861 10

admin 发表于 2013-10-4 14:10:19 PLM之家手机频道 |阅读模式

admin 楼主

2013-10-4 14:10:19

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x
Teamcenter二次开发实例教程-报表开发教程
8 T8 ~. x6 O' _6 \' R8 C" n& Q( J8 }  S$ p
   在大多数情况下,我们为客户做实施时,采用的是重新开发报表的功能。以满足客户多种多样的报表模板。然而Teamcenter8,9对报表开发有不错的支持。我们可以通过简单的配置开发出功能强大的报表。本文就Teamcenter OOTB报表技术展开讨论,希望能在众多报表开发方法中再增加一种可能性。
5 J. ^* B4 x0 y& f! p+ L   下面我对两类报表开发方式优缺点做了个简单对比* _6 m1 j- i& C$ @3 Q
. s) D: X% }- P
传统报表开发手段9 ~0 P0 u# N1 x' ~
OOTB报表/ V1 W* S& z: d, B6 d6 q0 ^
比分
  Y( _$ ]9 j. H( E; l$ }  l1
) j* P  E- r+ x9 T- J自定义模板,灵活多变1 @0 W! ^. J# L4 u# X$ |8 }
格式不能完全满足客户需求
- H3 B1 Z6 S5 O- o或非常难满足客户需求$ j6 ]* E( B8 B; r
1:0$ u2 }4 m: ~+ l$ Y6 [9 \
2: u& y* s. W6 f( U+ a
大量开发和代码维护5 v# o6 N1 N& K3 a9 T% P
或用POI,Excel报表
3 s' C3 F6 i& M/ i2 ?开发量小,仅需简单配置- u2 ]* p3 H- {5 f% p" U
1:1
( S! |8 N9 g0 `31 F7 Z9 q1 a8 z3 T
遇到大数据量报表生成不了, Y' e+ y+ V% _7 t9 M' H, m6 a* M
速度很慢
) n+ s/ X9 K0 o$ L! P7 m! Z处理大数据量有优势
: w2 A) T/ t3 _- {" G速度非常快
, [1 {3 B  C; m4 Z$ p$ O1:2
" e' \- x4 {6 L3 {4 r8 C5 W- p4
# D3 X! R  F2 x. W+ x# _& Z. C- h开发周期长,BUG+ ]: K# d1 r3 n8 x0 W+ B5 c. Z: J
开发迅速容易7 [6 i0 u- h6 P- O( g/ Y/ R% \
1:36 n2 s0 y/ W8 S4 H4 b2 l7 w

0 m# s0 \* [& D4 z一、报表生成$ m9 z$ r4 E' g0 u& T
首先来开OOTB的零部件BOM) g: k% ~4 g& B' a  P: b

. i, Y  q9 g3 [8 a( h  |3 A& F右键点击顶层部件,生成报告。
+ j: j0 N. R; C4 z& R
( Y5 @: j+ {2 }9 k8 F- ]& K+ |" u5 ^出现报告生成向导界面,选择PS – BOM结构,下一步* {5 L: J" h) H7 W$ N) |9 J& `/ ^3 C

2 G& K8 [9 l# C$ tOOTB为我们提供了两种方式的报表:1 `, [) R3 r+ a* x
 HTML
4 V5 A# b# x1 b; @0 k XSL
$ F+ {# b9 L6 W# K& Z每种报表都有对多国语言支持版本,所以下面对话框中有4个选项。我们选第一个。
  p  c: W: y! ]1 C6 c/ p
+ g9 x  Y, O" d$ _; n0 W! n生成报表如下:6 S5 g) x1 p8 T3 E* s

' p" d0 q8 T- ]  p7 q7 @8 U) f . O/ L; E/ k6 n- O4 _4 q& ~* K
二、报表配置; r, }5 \: q& T! o
报表配置涉及两个Teamcenter应用程序:1 J. f8 Q% G; i& S* ?
 报表构建器
% D: h# A# E* s. J) j  i PLMXML
9 F* y  }9 C" Z# K报表构建器主要定义报表所应用的资源、模板文件和PLMXML导出规则
" O) P: F1 U6 k7 _4 F. [/ [7 b4 n) U5 y: u) ]  v7 l4 W% G3 e. j* ~
PLMXML主要负责以PLMXML格式导出BOM数据# ?: o& ?8 j. f& [3 J6 Z

! J$ W9 v# @; }% a8 G+ e 8 E( `3 M) L5 s5 Z
三、应用举例
2 w+ a, d8 p8 g- |   下面对于一个具有广泛统计意义的功能用OOTB报表方式来实现。需求是:统计零件在整个BOM中的使用次数。4 y  l9 p$ _3 u" J% n6 ]  O, P9 u
   对于这个需求我们只需要增加一段带计算功能的代码就能实现。先通过系统的搜索功能找到html报表模板文件。
+ h5 G) W% T: v. j% U( k5 Q6 }( o! ^, \& w. ?
选中找到的数据,右击,命名引用。: ~* d9 z9 C# u, ^! u; q- g/ P. ]

) H! m4 ~! b( S( V$ k% P2 o点击导出,把模板保存到本地。
. E. \; T/ n; @! k; v4 H4 ^( t- |1 f& @" \5 Q/ E
下面对Javascript有一定要求。
5 |+ |" j& b0 f! \4 @! ^首先对表格增加一列来容纳计算的总数量:! q6 {7 j5 _4 u; T$ B2 X

5 N( U  w. _$ W1 J: }; y在xsl中找到上面两处代码增加、修改红框部分。0 R( Y+ @. r3 ?
定义如下函数,并且在onload事件中调用, Z, s( I5 A/ G% W  L; H- G
function showPart(){
- P' N" e8 Q% B  R​​​//获取html的表格对象
2 e( k$ K  q! F2 S/ y! g4 P  b4 {​​​​var tb = document.getElementById("table");5 r( U" U( |8 B) @7 p
​​​​//获取表格行对象
2 ?- i  `* L6 G& I2 f' g​​​​var rows = tb.rows;
0 v4 N6 V4 s+ ^​​​​//循环遍历table所有行) i; d: z7 Y. u) s* r) h! n
​​​​for(var i = 3; rows.length>i; i++){
1 j6 i; Y7 T8 K8 P# a​​​​​//获取每一行的零件号
0 P. b3 N& l5 D) s+ p​​​​​var itemName = rows[i].cells[1].childNodes[0].innerHTML;
( C, g/ h+ E# @/ N: p5 W​​​​​//初始化零件总个数) D: |- P0 C$ y( N, W8 e8 Z
​​​​​var quantity = 0;
8 W; x. h, x# s! h0 U$ `​​​​​//循环进行比较1 r/ e8 V' d9 j. `2 ^$ o" c. k
​​​​​for(var n = 3; rows.length>n; n++){' V* g5 I9 {* S  v
​​​​​​//获取每一行的零件号& X2 X& E+ j! ~  {7 o
​​​​​​var itemStr = rows[n].cells[1].childNodes[0].innerHTML;
# `# @$ m8 e7 K​​​​​​//获取零件数量( z- w8 {) C* w% U# z1 c
​​​​​​var qt = rows[n].cells[4].childNodes[0].innerHTML;. Q3 E6 e  i$ T1 W  |7 A9 F
​​​​​​//判断是否是相同的零件
4 W5 D8 c4 Q$ P7 w  ^+ b8 Y+ e​​​​​​if(itemStr == itemName){; N; Q$ K, i6 A; T5 m
​​​​​​​//若零件号相同,把数量进行累加
3 R  o, x5 q) `% w" `4 r8 W​​​​​​​quantity = parseInt(quantity) + parseInt(qt);9 D2 @7 [8 d6 i4 u1 Z
​​​​​​}​8 A$ r" A$ h2 L
​​​​​}
5 x5 r3 b0 ?* t+ l' k4 a' n& t3 J' U​​​​​//在统计列显示总数量4 P4 o6 i& B) Y& \9 w9 t
​​​​​rows[i].cells[5].childNodes[0].innerHTML = quantity;; C0 p/ ?# c% G
​​​​}+ i; ]6 k' u' P
​​​}  ?% D7 E" q; ]8 O1 u
修改好后,保存回源数据集。注意先删除原来的再导入新的。2 |; e3 S$ W. b

) t! J: o# o$ W+ v+ P  t8 o% X! _$ B; l
$ i; f" G5 |( I& ]$ e重新生成报表测试下:* K( W( s7 K0 c2 O
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

全部回复10

magic_benny 发表于 2014-12-19 13:38:29

magic_benny 板凳

2014-12-19 13:38:29

支持一下楼主,谢谢了
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

ke111026 发表于 2015-12-1 14:03:02

ke111026 地板

2015-12-1 14:03:02

ddddddddddddddd
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

linnan 发表于 2017-4-11 16:52:27

linnan 6#

2017-4-11 16:52:27

支持楼主,非常感谢。
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

656290267 发表于 2018-6-3 11:17:10

656290267 7#

2018-6-3 11:17:10

必须认真学习这类资料。
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

Edison 发表于 2018-7-4 16:08:19

Edison 8#

2018-7-4 16:08:19

666666,给力
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

jcy2024 发表于 2018-10-12 11:15:15

jcy2024 9#

2018-10-12 11:15:15

632255555555
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

zhu.boo@163.com 发表于 2019-7-10 18:59:24

zhu.boo@163.com 10#

2019-7-10 18:59:24

ddddddddddd
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了