前面是我判断的逻辑
" append component to componentstable
CASE gs_component-name.
WHEN 'DOCUMENTHEADER_Z_DOC_DATE'.
gs_component-type ?= cl_abap_elemdescr=>get_string( ).
APPEND gs_component TO gt_components.
WHEN 'DOCUMENTHEADER_Z_PSTNG_DATE'.
gs_component-type ?= cl_abap_elemdescr=>get_string( ).
APPEND gs_component TO gt_components.
WHEN 'ACCOUNTGL_Z_VALUE_DATE'.
gs_component-type ?= cl_abap_elemdescr=>get_string( ).
APPEND gs_component TO gt_components.
WHEN OTHERS.
gs_component-type ?= cl_abap_datadescr=>describe_by_data( <fs_field> ).
APPEND gs_component TO gt_components.
ENDCASE.
gs_component_upl-type ?= cl_abap_datadescr=>describe_by_data( <fs_field_upl> ).
APPEND gs_component_upl TO gt_components_upl.
通过 CONVERT_DATE_TO_INTERNAL来实现
" convert dates to internal format
IF gs_component-name EQ 'DOCUMENTHEADER_Z_DOC_DATE' OR gs_component-name EQ 'DOCUMENTHEADER_Z_PSTNG_DATE' OR gs_component-name EQ 'ACCOUNTGL_Z_VALUE_DATE'." Inserted by ERDK909923
CALL FUNCTION 'CONVERT_DATE_TO_INTERNAL'
EXPORTING
date_external = <fs_fname>
IMPORTING
date_internal = <fs_fname2>
EXCEPTIONS
date_external_is_invalid = 1
OTHERS = 2.
IF sy-subrc <> 0.
<fs_fname2> = <fs_fname>.
ENDIF.
ELSE.
<fs_fname2> = <fs_fname>.
ENDIF.