ABAP MS_EXCEL_OLE_STANDARD_DAT的Bug

REPORT z_barry_test NO STANDARD PAGE HEADING LINE-SIZE 240.

DATA: BEGIN OF itab OCCURS 0,
        ff1(10) TYPE c,
        ff2(10) TYPE n,
        ff3 TYPE d,
        ff4 TYPE t,
        ff5 TYPE p DECIMALS 2,
       END OF itab.

DATA: BEGIN OF itab_field OCCURS 0,
        fname(40) TYPE c ,
      END OF itab_field.

itab-ff1 = '测试ABC'.
itab-ff2 = '1234'.
itab-ff3 = '20100120'.
itab-ff4 = '163145'.
itab-ff5 = '13244.34'.
APPEND itab.

itab_field-fname = 'F1'.
APPEND itab_field.
itab_field-fname = 'F2'.
APPEND itab_field.
itab_field-fname = 'F3'.
APPEND itab_field.
itab_field-fname = 'F4'.
APPEND itab_field.
itab_field-fname = '5'. "针对非C、N、D、T类型列的列名,函数有Bug
APPEND itab_field.

CALL FUNCTION 'EXCEL_OLE_STANDARD_DAT'
  EXPORTING
    file_name                 = 'C:\TEST1'
    create_pivot              = 0
    data_sheet_name           = 'TEST 1'
  TABLES
    data_tab                  = itab
    fieldnames                = itab_field
  EXCEPTIONS
    file_not_exist            = 1
    filename_expected         = 2
    communication_error       = 3
    ole_object_method_error   = 4
    ole_object_property_error = 5
    invalid_filename          = 6
    invalid_pivot_fields      = 7
    download_problem          = 8
    OTHERS                    = 9.

CALL FUNCTION 'MS_EXCEL_OLE_STANDARD_DAT'
  EXPORTING
    file_name                 = 'C:\TEST2'
    data_sheet_name           = 'TEST 2'
  TABLES
    data_tab                  = itab
    fieldnames                = itab_field
  EXCEPTIONS
    file_not_exist            = 1
    filename_expected         = 2
    communication_error       = 3
    ole_object_method_error   = 4
    ole_object_property_error = 5
    invalid_filename          = 6
    invalid_pivot_fields      = 7
    download_problem          = 8
    OTHERS                    = 9.

Bug有两个:

1、Fieldname数据类型会被强制转变为对应列的类型,如果转换失败则Dump

2、如果连续两次或两次以上以上调用,列名会跑到数据区

另外,如果要导出的数据有中文且本机操作系统不是中文,则GUI须用中文登录

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值