Smartforms在同一页中打印多份模板,打印动态表格

要求:

一:需要在一份A4纸中打印上下两个表格,每个表格行只有5行,不够的需要补齐,超出的需要打印到第二个表格中.

二:表格不是固定的,需要根据某个字段,确定使用的表格格式

 

解决方法,我们只需要创建一个模板高度的数据模板,通过循环来打印我们的模板,相当于每次印半页,印两次就是一页.

 

 

下面是详细步骤

  1. 根据要求一,Smartforms初始化时,需要对表做补行处理.具体代码如下

 

 1 LOOP AT gt_output INTO gs_output.
 2   IF line_exists( gt_item[ belnr = gs_output-belnr ] ).
 3     "计算表中数据除5求余
 4     gv_line = lines( VALUE znfit0010_i( FOR wa IN gt_item WHERE ( belnr = gs_output-belnr ) ( wa ) ) ) MOD 5.
 5     "余数大于0,添加5-余数的空白行
 6     IF gv_line > 0.
 7       DO 5 - gv_line TIMES.
 8         APPEND VALUE #( belnr = gs_output-belnr ) TO gt_item.
 9       ENDDO.
10     ENDIF.
11   ENDIF.
12 ENDLOOP.
13 
14 GV_COUNTS = LINES( GT_OUTPUT ).”用于计算总凭证数量

 

 

  1. Smartforms使用双循环

先循环Header,再循环Item

 

计算里面获取一下循环次数到GV_COUNT

 

循环ITEM

 

条件是Header的凭证号

获取Item行的循环计数,用于创建新表格

 

  1. 创建一个新变量,用于控制表头输出

 

当值为Y时,输出表头,值为N时,不输出

  1. 输出表尾的时候的条件,其中包括输出表头条件

 

表尾输出后,把值改为Y,从而输出表头

 

当不满足输出表尾和表头的时候,把值设置为N,从而不输出表头

 

根据要求二,我们要根据不同的货币输出不同的表内容

解决方法是我们可以通过条件判断什么时候输出表格一,什么时候输出表格二.只要两个条件不重合,那系统只会输出符合条件的表格.

 

 

 

posted on 2024-08-01 12:34  艺高人胆大  阅读(8)  评论(0编辑  收藏  举报