要求:
一:需要在一份A4纸中打印上下两个表格,每个表格行只有5行,不够的需要补齐,超出的需要打印到第二个表格中.
二:表格不是固定的,需要根据某个字段,确定使用的表格格式
解决方法,我们只需要创建一个模板高度的数据模板,通过循环来打印我们的模板,相当于每次印半页,印两次就是一页.
下面是详细步骤
- 根据要求一,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 ).”用于计算总凭证数量
- Smartforms使用双循环
先循环Header,再循环Item
计算里面获取一下循环次数到GV_COUNT
循环ITEM
条件是Header的凭证号
获取Item行的循环计数,用于创建新表格
- 创建一个新变量,用于控制表头输出
当值为Y时,输出表头,值为N时,不输出
- 输出表尾的时候的条件,其中包括输出表头条件
表尾输出后,把值改为Y,从而输出表头
当不满足输出表尾和表头的时候,把值设置为N,从而不输出表头
根据要求二,我们要根据不同的货币输出不同的表内容
解决方法是我们可以通过条件判断什么时候输出表格一,什么时候输出表格二.只要两个条件不重合,那系统只会输出符合条件的表格.
标签:Smartforms,表格,打印,输出表,belnr,output,模板 From: https://www.cnblogs.com/anter/p/18336419