SAP 金税接口代码 供参考
程序可以通过抓取 客户 开票信息等 下载文本 导出
需要事先创建好几个structure
zc0000sdt0016,
zc0000sdt0017
REPORT zc0000sdr0016 NO STANDARD PAGE HEADING LINE-COUNT 58 LINE-SIZE 170. TABLES:vbrk,vbrp,t001. *----------------------------------------------------------------------* * type define *----------------------------------------------------------------------* TYPES: BEGIN OF ty_vbrk, vbeln TYPE vbrk-vbeln,"invoice number fkart TYPE vbrk-fkart, "ERPInvoiceType waerk TYPE vbrk-waerk, "Currency vkorg TYPE vbrk-vkorg, "Sales Organization vtweg TYPE vbrk-vtweg, "Distribution Channel knumv TYPE vbrk-knumv, fkdat TYPE vbrk-fkdat, "Invoice data gjahr TYPE vbrk-gjahr, "Year bukrs TYPE vbrk-bukrs, taxk1 TYPE vbrk-taxk1, "Invoice type(eg:0 - Expore Invoice, 1 - VAT Inovice , 2 - Credit Inovice)BillingType kunag TYPE vbrk-kunag, "Customer code sfakn TYPE vbrk-sfakn, "Credit Notes fksto TYPE vbrk-fksto, "Cancel flag del TYPE c, END OF ty_vbrk, BEGIN OF ty_vbrp, vbeln TYPE vbrp-vbeln, "Invoice number posnr TYPE vbrp-posnr, "Item number fkimg TYPE vbrp-fkimg, "Quantity vrkme TYPE vbrp-vrkme, "Unit netwr TYPE vbrp-netwr, "Sum vbelv TYPE vbrp-vbelv, "First Document aubel TYPE vbrp-aubel, "Sales Document matnr TYPE vbrp-matnr, "Material Number arktx TYPE vbrp-arktx, "Product chinese name ernam TYPE vbrp-ernam, "Person code mwsbp TYPE vbrp-mwsbp, "Tax END OF ty_vbrp, BEGIN OF ty_out, txt TYPE string, END OF ty_out, BEGIN OF ty_errlog, "Linda 20141120 add str(100) TYPE c, "Linda 20141120 add END OF ty_errlog. "Linda 20141120 add *----------------------------------------------------------------------* * Internal Tables define *----------------------------------------------------------------------* DATA: it_blitems TYPE STANDARD TABLE OF zc0000sdt0016,"is struction it_tbillno TYPE STANDARD TABLE OF zc0000sdt0017,"is table, it_kunnr TYPE jito_kunnr_range_tt, it_vbeln TYPE jit_vbeln_vl_range_tt, it_out TYPE STANDARD TABLE OF ty_out,"use for output it_errlog TYPE STANDARD TABLE OF ty_errlog, "Linda 20141120 add *----------------------------------------------------------------------* * Workarea define *----------------------------------------------------------------------* iw_vbrk TYPE ty_vbrk, iw_tbillno TYPE zc0000sdt0017,"is table iw_blitems TYPE zc0000sdt0016,"is struction iw_kunnr TYPE jito_kunnr_range, iw_vbeln TYPE jit_vbeln_vl_range, iw_out TYPE ty_out, iw_errlog TYPE ty_errlog, "Linda 20141120 add *----------------------------------------------------------------------* * Variables define *----------------------------------------------------------------------* w_time TYPE char6, "run time w_path TYPE rlgrap-filename, "path w_filename TYPE rlgrap-filename, "file name w_data1 TYPE i, w_data2 TYPE i, w_filter TYPE string." VALUE 'Text Files(*.txt)|*.txt'.Linda 20141024 *----------------------------------------------------------------------* * Constants define *----------------------------------------------------------------------* CONSTANTS: cos_vl TYPE char1 VALUE '\', cos_open TYPE char4 VALUE 'OPEN', cos_close TYPE char5 VALUE 'CLOSE', cos_transfer TYPE char8 VALUE 'TRANSFER', cos_comma TYPE char1 VALUE ','. "Linda 20141120 add SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE text-003. PARAMETERS:"p_batch TYPE char20, "batch 1 p_bukrs TYPE vbrk-bukrs OBLIGATORY. "company SELECT-OPTIONS:s_fkdat FOR vbrk-fkdat NO-EXTENSION. "Billing date for billing index and printout 2 SELECTION-SCREEN BEGIN OF LINE . SELECTION-SCREEN COMMENT 1(31) text-009 . "enter data range PARAMETER p_data1 TYPE char3. SELECTION-SCREEN COMMENT 40(4) text-010. PARAMETER p_data2 TYPE char3. SELECTION-SCREEN COMMENT 70(79) text-008. SELECTION-SCREEN END OF LINE. SELECT-OPTIONS: s_vbeln FOR vbrk-vbeln, "Billing Document 3 s_kunag FOR vbrk-kunag, "Payer 4 s_matnr FOR vbrp-matnr NO-EXTENSION, "Material Number 5 s_aubel FOR vbrp-aubel NO-EXTENSION, "Sales Document 6 s_vkorg FOR vbrk-vkorg NO-EXTENSION OBLIGATORY. PARAMETERS:p_gjahr TYPE vbrk-gjahr. "Fiscal Year PARAMETERS:p_nonrep TYPE c AS CHECKBOX. "compare or not SELECTION-SCREEN END OF BLOCK b1. SELECTION-SCREEN BEGIN OF LINE. PARAMETER p_check3 RADIOBUTTON GROUP rad DEFAULT 'X' USER-COMMAND rad. SELECTION-SCREEN COMMENT 4(20) text-c03 FOR FIELD p_check3."TXT format PARAMETER p_check4 RADIOBUTTON GROUP rad. SELECTION-SCREEN COMMENT 28(30) text-c04 FOR FIELD p_check4."CSV format SELECTION-SCREEN END OF LINE. SELECTION-SCREEN BEGIN OF BLOCK b3 WITH FRAME TITLE text-002. SELECTION-SCREEN BEGIN OF LINE. PARAMETER p_check2 TYPE c RADIOBUTTON GROUP rads DEFAULT 'X' USER-COMMAND rad2. SELECTION-SCREEN COMMENT 4(20) text-c02 FOR FIELD p_check2."output to server SELECTION-SCREEN END OF LINE. PARAMETERS: p_path2(1024) TYPE c LOWER CASE VISIBLE LENGTH 200. SELECTION-SCREEN BEGIN OF LINE. PARAMETER p_check1 RADIOBUTTON GROUP rads. SELECTION-SCREEN COMMENT 4(20) text-c01 FOR FIELD p_check1." SELECTION-SCREEN END OF LINE. PARAMETERS: p_path(1024) TYPE c LOWER CASE VISIBLE LENGTH 200. SELECTION-SCREEN END OF BLOCK b3. *----------------------------------------------------------------------* * INITIALIZATION *----------------------------------------------------------------------* INITIALIZATION. * init *----------------------------------------------------------------------* * AT SELECTION-SCREEN ON VALUE-REQUEST *----------------------------------------------------------------------* AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_path. PERFORM frm_save_file CHANGING p_path. *----------------------------------------------------------------------* * AT SELECTION-SCREEN OUTPUT *----------------------------------------------------------------------* AT SELECTION-SCREEN OUTPUT. IF p_data1 <> space AND p_data2 <> space. "Linda 20141120 add REFRESH:s_fkdat. "Linda 20141024 add ENDIF. "Linda 20141120 add IF p_data1 <> space AND p_data2 <> space. PERFORM frm_chang_data USING p_data1 CHANGING s_fkdat-low. PERFORM frm_chang_data USING p_data2 CHANGING s_fkdat-high. APPEND s_fkdat. ENDIF. *----------------------------------------------------------------------* * AT SELECTION-SCREEN *----------------------------------------------------------------------* AT SELECTION-SCREEN. * WHEN 'ONLI'. PERFORM frm_init. IF p_path = space AND p_check1 = 'X'. SET CURSOR FIELD 'P_PATH'. MESSAGE e001(00) WITH 'Local path can not be space'(018). ENDIF. IF p_path2 = space AND p_check2 = 'X'. SET CURSOR FIELD 'P_PATH2'. MESSAGE e001(00) WITH 'Server path can not be space'(017). ENDIF. CASE sy-ucomm. WHEN 'RAD' OR 'RAD2'. * lw_filter = 'Text Files(*.txt)|*.txt|Csv Files(*.csv)|*.csv|Excel Files(*.xls)|*.xls|All Files(*.*)|*.*|'."Text Files(*.txt)|*.txt|'. "All Files(*.*)|*.*| IF p_check3 = 'X'. w_filter = 'Text Files(*.txt)|*.txt'(020). ELSEIF p_check4 = 'X'. w_filter = 'Csv Files(*.csv)|*.csv'(021). ENDIF. CLEAR: p_path, p_path2. WHEN OTHERS. ENDCASE. TRY. w_data1 = p_data1. w_data2 = p_data2. CATCH cx_root. SET CURSOR FIELD 'P_DATA1'. MESSAGE e001(00) WITH 'Data range must be number'(014). ENDTRY. IF w_data1 > w_data2. SET CURSOR FIELD 'P_DATA1'. MESSAGE e001(00) WITH 'Data range must from small to big'(015). ENDIF. *----------------------------------------------------------------------* * START-OF-SELECTION *----------------------------------------------------------------------* START-OF-SELECTION. w_time = sy-uzeit. IF s_fkdat[] IS INITIAL AND p_data1 <> space AND p_data2 <> space. PERFORM frm_chang_data USING p_data1 CHANGING s_fkdat-low. PERFORM frm_chang_data USING p_data2 CHANGING s_fkdat-high. s_fkdat-sign = 'I'. s_fkdat-option = 'BT'. APPEND s_fkdat. ELSEIF s_fkdat[] IS INITIAL AND p_data1 = space AND p_data2 = space. MESSAGE s001(00) WITH text-022 text-025 DISPLAY LIKE 'E'. RETURN. LEAVE TO LIST-PROCESSING. ENDIF. LOOP AT s_kunag. iw_kunnr-sign = s_kunag-sign. iw_kunnr-option = s_kunag-option. iw_kunnr-low = s_kunag-low. iw_kunnr-high = s_kunag-high. APPEND iw_kunnr TO it_kunnr. ENDLOOP. LOOP AT s_vbeln. iw_vbeln-sign = s_vbeln-sign. iw_vbeln-option = s_vbeln-option. iw_vbeln-low = s_vbeln-low. iw_vbeln-high = s_vbeln-high. APPEND iw_vbeln TO it_vbeln. ENDLOOP. CHECK it_errlog IS INITIAL. CALL FUNCTION 'ZBPI_FW_INVOICE_MAHLE_NEW' EXPORTING fkdat_fr = s_fkdat-low vbeln_fr = s_vbeln-low kunnr_fr = s_kunag-low matnr_fr = s_matnr-low fkdat_to = s_fkdat-high vbeln_to = s_vbeln-high kunnr_to = s_kunag-high matnr_to = s_matnr-high aubel_fr = s_aubel-low aubel_to = s_aubel-high vkorg_fr = s_vkorg-low vkorg_to = s_vkorg-high * disc_cond_type = p_disc * unit_cond_type = p_unit * tax_cond_type = p_tax bukrs = p_bukrs nonrepeat = p_nonrep gjahr = p_gjahr TABLES zfw_billing_items = it_blitems zfw_billingno = it_tbillno zfw_kunnr = it_kunnr zfw_vbeln = it_vbeln EXCEPTIONS no_data = 1 lock_errord = 2 insert_error = 3. CASE sy-subrc. WHEN 1. iw_errlog-str = 'No matching data is found.'(012). APPEND iw_errlog TO it_errlog. WHEN 2. iw_errlog-str = 'Lock table error.'(023). APPEND iw_errlog TO it_errlog. WHEN 3. iw_errlog-str = 'Insert table error.'(026). APPEND iw_errlog TO it_errlog. ENDCASE. CHECK it_errlog IS INITIAL. **{ Insert started by Linda on 06-Jan-2015 - CRXX PERFORM frm_modify_blitems. * **} Insert ended by Linda on 06-Jan-2015 - CRXX * background process IF p_check2 = 'X'. PERFORM frm_transfer_sever. ELSE. * front process PERFORM frm_transfer_loc. ENDIF. *----------------------------------------------------------------------* * END-OF-SELECTION *----------------------------------------------------------------------* END-OF-SELECTION. * error log print LOOP AT it_errlog INTO iw_errlog." WRITE: /1 iw_errlog-str. ENDLOOP. FREE:it_tbillno, it_out, iw_vbrk, iw_tbillno, iw_blitems, it_vbeln, it_kunnr, it_blitems, w_time, w_path, w_filename, iw_out. *&---------------------------------------------------------------------* *& Form frm_transfer_sever *&---------------------------------------------------------------------* * text *----------------------------------------------------------------------* * --> p1 text * <-- p2 text *----------------------------------------------------------------------* FORM frm_transfer_sever . * 拼接文件名 IF p_check3 = 'X'. CONCATENATE p_bukrs s_vkorg-low sy-datum "LINDA 20140916 w_time '.txt' INTO w_filename. ELSEIF p_check4 = 'X'. CONCATENATE p_bukrs s_vkorg-low sy-datum "LINDA 20140916 w_time '.csv' INTO w_filename. ENDIF. * 拼接服务器路径 CONCATENATE p_path2 w_filename INTO w_path SEPARATED BY cos_vl. * 打开服务器文件 编码是非unicode * OPEN DATASET w_path FOR OUTPUT IN TEXT MODE ENCODING NON-UNICODE. * 打开服务器文件 编码是unicode OPEN DATASET w_path FOR OUTPUT IN TEXT MODE ENCODING UTF-8. * 打开成功 IF sy-subrc = 0. * 读取 PERFORM frm_write_txt. * 关闭 DATASET TRY. CLOSE DATASET w_path. IF sy-subrc <> 0. * 文件名 &1 &2 &3 操作出错 MESSAGE s001(00) WITH 'File name' w_filename cos_close 'operate Error' INTO iw_errlog-str. "Linda 20141119 ELSE. * 导出成功 MESSAGE s001(00) WITH 'Output successful' INTO iw_errlog-str. ENDIF. CATCH cx_root. "#EC CATCH_ALL MESSAGE s001(00) WITH 'File name' w_filename cos_close 'operate Error' INTO iw_errlog-str. "Linda 20141119 CLEANUP. ENDTRY. ELSE. * 文件名 &1 &2 &3 操作出错 MESSAGE s001(00) WITH 'File name' w_filename cos_open 'operate Error' INTO iw_errlog-str. "Linda 20141119 ENDIF. APPEND iw_errlog TO it_errlog. CLEAR:w_filename, w_path. ENDFORM. " frm_transfer_sever *&---------------------------------------------------------------------* *& Form frm_transfer_loc *&---------------------------------------------------------------------* * text *----------------------------------------------------------------------* * -->p1 text * <--p2 text *----------------------------------------------------------------------* FORM frm_transfer_loc. DATA:lw_file TYPE string. * 拼接download数据 LOOP AT it_blitems INTO iw_blitems. PERFORM frm_con_string USING iw_blitems CHANGING iw_out-txt. APPEND iw_out TO it_out. CLEAR: iw_blitems,iw_out. ENDLOOP. lw_file = p_path. CALL FUNCTION 'GUI_DOWNLOAD' EXPORTING filename = lw_file "string filetype = 'ASC' codepage = '8400' "4110 是utf-8 write_bom = 'X' TABLES data_tab = it_out EXCEPTIONS file_write_error = 1 no_batch = 2 gui_refuse_filetransfer = 3 invalid_type = 4 no_authority = 5 unknown_error = 6 header_not_allowed = 7 separator_not_allowed = 8 filesize_not_allowed = 9 header_too_long = 10 dp_error_create = 11 dp_error_send = 12 dp_error_write = 13 unknown_dp_error = 14 access_denied = 15 dp_out_of_memory = 16 disk_full = 17 dp_timeout = 18 file_not_found = 19 dataprovider_exception = 20 control_flush_error = 21 OTHERS = 22. IF sy-subrc <> 0. MESSAGE ID sy-msgid TYPE 'S' NUMBER sy-msgno DISPLAY LIKE 'E' WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4. ELSE. iw_errlog-str = 'Output success.'(024). APPEND iw_errlog TO it_errlog. ENDIF. ENDFORM. " frm_transfer_loc *&---------------------------------------------------------------------* *& Form frm_save_file *&---------------------------------------------------------------------* * text *----------------------------------------------------------------------* * <--f_path text *----------------------------------------------------------------------* FORM frm_save_file CHANGING f_path TYPE file_table-filename. DATA: lw_fname TYPE string, lw_path TYPE string, lw_fpath TYPE string. CALL METHOD cl_gui_frontend_services=>file_save_dialog EXPORTING file_filter = w_filter CHANGING filename = lw_fname path = lw_path fullpath = lw_fpath EXCEPTIONS cntl_error = 1 error_no_gui = 2 not_supported_by_gui = 3 OTHERS = 4. IF sy-subrc <> 0. MESSAGE ID sy-msgid TYPE 'E' NUMBER sy-msgno WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4. ENDIF. f_path = lw_fpath. ENDFORM. " frm_save_file *&---------------------------------------------------------------------* *& Form frm_con_string *&---------------------------------------------------------------------* * text *----------------------------------------------------------------------* * -->piw_blitem text * <--pw_txt text *----------------------------------------------------------------------* FORM frm_con_string USING piw_blitem TYPE zc0000sdt0016 CHANGING pw_txt TYPE string. DATA: lw_temp TYPE char1024. FIELD-SYMBOLS: <fs_temp> TYPE ANY. DO. ASSIGN COMPONENT sy-index OF STRUCTURE piw_blitem TO <fs_temp>. IF sy-subrc <> 0. EXIT. ENDIF. CLEAR lw_temp. lw_temp = <fs_temp>. * 去空格 SHIFT lw_temp LEFT DELETING LEADING space. IF sy-index = 1. pw_txt = lw_temp. ELSE. IF p_check3 = 'X'. "Linda 20141120 add CONCATENATE pw_txt cl_abap_char_utilities=>horizontal_tab lw_temp INTO pw_txt. ELSEIF p_check4 = 'X'. CONCATENATE pw_txt cos_comma lw_temp "Linda 20141120 add INTO pw_txt. * ELSE. * CONCATENATE pw_txt cos_comma lw_temp * INTO pw_txt. ENDIF. ENDIF. ENDDO. UNASSIGN <fs_temp>. ENDFORM. " frm_con_string *&---------------------------------------------------------------------* *& Form frm_write_txt *&---------------------------------------------------------------------* * text *----------------------------------------------------------------------* * --> p1 text * <-- p2 text *----------------------------------------------------------------------* FORM frm_write_txt . DATA:lw_out TYPE string. ** 上传数据头 ** 捕获异常 * TRY. ** 上传服务器 * lw_out = LINES( it_blitems ). * CONCATENATE w_filename '#Record' lw_out * INTO lw_out. * CONDENSE lw_out. * TRANSFER lw_out TO w_path. ** 判断传输是否成功 * IF sy-subrc <> 0. ** 文件名 &1 &2 &3 操作出错 * MESSAGE s001(00) WITH 'File name' w_path cos_transfer 'operate error'. * ENDIF. * CATCH cx_root. * MESSAGE s001(00) WITH 'File name' w_path cos_transfer 'operate error'. * CLEANUP. * ENDTRY. * 上传数据 LOOP AT it_blitems INTO iw_blitems. PERFORM frm_con_string USING iw_blitems CHANGING lw_out. TRY. TRANSFER lw_out TO w_path. * 判断传输是否成功 IF sy-subrc <> 0. * 文件名 &1 &2 &3 操作出错 MESSAGE s001(00) WITH 'File name' w_path cos_transfer 'operate error'. ENDIF. CATCH cx_root. MESSAGE s001(00) WITH 'File name' w_path cos_transfer 'operate error'. CLEANUP. ENDTRY. CLEAR: iw_blitems,lw_out. ENDLOOP. ENDFORM. " frm_write_txt *&---------------------------------------------------------------------* *& Form frm_chang_data *&---------------------------------------------------------------------* * text *----------------------------------------------------------------------* * -->fw_data text * <--fw_budat text *----------------------------------------------------------------------* FORM frm_chang_data USING fw_data CHANGING fw_budat. DATA:l_today TYPE p0001-begda, lw_data TYPE t5a4a-dlydy, lw_calc TYPE p0001-begda. * lw_data2 LIKE sy-datum. l_today = sy-datum. lw_data = fw_data. IF fw_data = 0. fw_budat = sy-datum. ELSEIF fw_data > 0. CALL FUNCTION 'RP_CALC_DATE_IN_INTERVAL' EXPORTING date = l_today days = lw_data months = 0 signum = '+' years = 0 IMPORTING calc_date = lw_calc. fw_budat = lw_calc . ELSE. CALL FUNCTION 'RP_CALC_DATE_IN_INTERVAL' EXPORTING date = l_today days = lw_data months = 0 signum = '-' years = 0 IMPORTING calc_date = lw_calc. fw_budat = lw_calc . ENDIF. ENDFORM. " frm_chang_data *&---------------------------------------------------------------------* *& Form frm_init *&---------------------------------------------------------------------* * text *----------------------------------------------------------------------* * --> p1 text * <-- p2 text *----------------------------------------------------------------------* FORM frm_init . * SELECT * FROM t001 INTO t001. "Linda 20141204 del * authority-check AUTHORITY-CHECK OBJECT 'F_BKPF_BUK' ID 'BUKRS' FIELD p_bukrs ID 'ACTVT' FIELD '03'. IF sy-subrc <> 0. * You have no authorization for Company code MESSAGE e004(zp001) WITH p_bukrs. ENDIF. * ENDSELECT. "Linda 20141204 del ENDFORM. " frm_init **{ Insert started by Linda on 06-Jan-2015 - CR0001 *&---------------------------------------------------------------------* *& Form FRM_MODIFY_BLITEMS *&---------------------------------------------------------------------* * text *----------------------------------------------------------------------* * --> p1 text * <-- p2 text *----------------------------------------------------------------------* FORM frm_modify_blitems . DATA:lw_blitems TYPE zc0000sdt0016. LOOP AT it_blitems INTO lw_blitems. CALL FUNCTION 'CONVERSION_EXIT_CUNIT_OUTPUT' EXPORTING input = lw_blitems-vrkme language = sy-langu IMPORTING * LONG_TEXT = output = lw_blitems-vrkme * SHORT_TEXT = * EXCEPTIONS * UNIT_NOT_FOUND = 1 * OTHERS = 2 . IF sy-subrc <> 0. * MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO * WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4. ENDIF. MODIFY it_blitems FROM lw_blitems TRANSPORTING vrkme. ENDLOOP. ENDFORM. " FRM_MODIFY_BLITEMS
发票号码回传程序
1 REPORT zc0000sdr0017 NO STANDARD PAGE HEADING 2 LINE-COUNT 58 3 LINE-SIZE 170. 4 TYPE-POOLS: icon,slis,kcdu,tpit. 5 TABLES: sscrfields, 6 zc0000sdt0020. 7 *----------------------------------------------------------------------* 8 * type define 9 *----------------------------------------------------------------------* 10 TYPES: ty_dir_list TYPE STANDARD TABLE OF salfldir, 11 BEGIN OF ty_dir, 12 name TYPE pfeflname, 13 size TYPE pfeflsize, 14 name2 TYPE pfeflname, 15 END OF ty_dir, 16 BEGIN OF ty_tabl, 17 line(200), 18 END OF ty_tabl, 19 BEGIN OF ty_vbeln, 20 vbeln TYPE vbrk-vbeln, 21 fkart TYPE vbrk-fkart, 22 kunrg TYPE vbrk-kunrg, 23 bukrs TYPE vbrk-bukrs, 24 fkdat TYPE vbrk-fkdat, 25 xblnr TYPE xblnr, 26 gjahr TYPE gjahr, 27 bktxt TYPE bktxt, "linda 20140918 28 zline TYPE i, "bseg table lines "Linda 20141023 29 END OF ty_vbeln, 30 BEGIN OF ty_vbrk, 31 vbeln TYPE vbrk-vbeln, 32 bukrs TYPE vbrk-bukrs, 33 gjahr TYPE vbrk-gjahr, 34 xblnr TYPE vbrk-xblnr, 35 fkdat TYPE vbrk-fkdat, 36 END OF ty_vbrk, 37 * add local file read begin 38 BEGIN OF ty_row, 39 field TYPE char40, 40 END OF ty_row, 41 * add local file read end 42 BEGIN OF ty_errlog, "Linda 20141120 add 43 str(100) TYPE c, "Linda 20141120 add 44 END OF ty_errlog. "Linda 20141120 add 45 *----------------------------------------------------------------------* 46 * Internal Tables define 47 *----------------------------------------------------------------------* 48 DATA: it_file TYPE ty_dir_list, 49 it_file2 TYPE STANDARD TABLE OF ty_dir, 50 it_errtab TYPE tpit_t_errdoc, 51 it_buztab TYPE TABLE OF tpit_buztab, 52 it_fldtab TYPE tpit_t_fname, 53 it_tabl TYPE STANDARD TABLE OF ty_tabl WITH HEADER LINE, 54 it_errlog TYPE STANDARD TABLE OF zc0000sdt0020, 55 it_errlog2 TYPE STANDARD TABLE OF ty_errlog, "Linda 20141120 add 56 it_fieldcat TYPE slis_t_fieldcat_alv, 57 it_bseg TYPE STANDARD TABLE OF bseg." Linda 20141024 add 58 *&---------------------------------------------------------------------* 59 * Workarea define 60 *&---------------------------------------------------------------------* 61 DATA: iw_file TYPE salfldir, 62 iw_file2 TYPE ty_dir, 63 iw_ins TYPE ty_vbeln, 64 iw_vbrk TYPE ty_vbrk, 65 iw_err TYPE zc0000sdt0020, 66 iw_errlog TYPE ty_errlog, "Linda 20141120 add 67 iw_bseg TYPE bseg. 68 *----------------------------------------------------------------------* 69 * Global Variables 70 *----------------------------------------------------------------------* 71 DATA :w_ret TYPE char1, 72 w_cmd(100) TYPE c, 73 w_date TYPE sy-datum, 74 w_time TYPE char6, 75 w_read_file TYPE salfile-longname, 76 functxt TYPE smp_dyntxt, 77 ok_code TYPE sy-ucomm, 78 w_repid TYPE sy-repid, 79 w_str(1000) TYPE c, 80 putdahigh TYPE zc0000sdt0020-putda, 81 puttihigh TYPE zc0000sdt0020-putti, 82 vbelnhigh TYPE zc0000sdt0020-vbeln, 83 xblnrhigh TYPE zc0000sdt0020-xblnr, 84 w_file_path TYPE string, 85 w_lfile TYPE string, "file name 86 w_row_num TYPE char4, 87 w_msg_txt TYPE string. 88 *----------------------------------------------------------------------* 89 * Constants define 90 *----------------------------------------------------------------------* 91 CONSTANTS: cos_star2(3) TYPE c VALUE '*.*', 92 cos_2(2) TYPE c VALUE '2', 93 cos_1(1) TYPE c VALUE '1', 94 cos_numc(4) TYPE c VALUE 'NUMC'. 95 96 SELECTION-SCREEN: FUNCTION KEY 1 . 97 SELECTION-SCREEN BEGIN OF LINE. 98 PARAMETER p_check2 TYPE c RADIOBUTTON GROUP rads DEFAULT 'X'. 99 SELECTION-SCREEN COMMENT 4(20) text-c02 FOR FIELD p_check2."导出到服务器 100 SELECTION-SCREEN END OF LINE. 101 SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME. 102 PARAMETERS: p_fpath(1024) TYPE c DEFAULT 'g:\r3ftp\formware\writeback\nonprocess\',"need edit D:\usr\sap\put\Inbound\Nonprocess\ 103 p_bpath(1024) TYPE c DEFAULT 'g:\r3ftp\formware\writeback\bak\'." D:\usr\sap\put\Inbound\Backup\ 104 SELECTION-SCREEN END OF BLOCK b1. 105 SELECTION-SCREEN BEGIN OF LINE. 106 PARAMETER p_check1 RADIOBUTTON GROUP rads. 107 SELECTION-SCREEN COMMENT 4(20) text-c01 FOR FIELD p_check1."导出到本地 108 SELECTION-SCREEN END OF LINE. 109 SELECTION-SCREEN BEGIN OF BLOCK b2 WITH FRAME TITLE text-t01. 110 PARAMETERS: p_flpath(1024) TYPE c DEFAULT ''."need edit D:\usr\sap\put\Inbound\Nonprocess\ 111 * p_blpath(1024) TYPE c DEFAULT 'D:\Backup\'." D:\usr\sap\put\Inbound\Backup\ 112 SELECTION-SCREEN END OF BLOCK b2. 113 *----------------------------------------------------------------------* 114 * INITIALIZATION. 115 *----------------------------------------------------------------------* 116 INITIALIZATION. 117 functxt-icon_id = icon_biw_info_catalog. 118 functxt-icon_text = 'ERROR LOG'. 119 sscrfields-functxt_01 = functxt. 120 *----------------------------------------------------------------------* 121 * AT SELECTION-SCREEN ON VALUE-REQUEST 122 *----------------------------------------------------------------------* 123 AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_flpath. 124 PERFORM form_get_file_path_upload. 125 *----------------------------------------------------------------------* 126 * START-OF-SELECTION 127 *----------------------------------------------------------------------* 128 START-OF-SELECTION. 129 w_date = sy-datum. 130 w_time = sy-uzeit. 131 * file process 132 IF p_check2 IS NOT INITIAL. 133 PERFORM frm_file_process. 134 ELSE. 135 * local 136 PERFORM frm_file_process_local. 137 ENDIF. 138 *----------------------------------------------------------------------* 139 * AT SELECTION-SCREEN 140 *----------------------------------------------------------------------* 141 AT SELECTION-SCREEN. 142 IF sy-ucomm = 'ONLI'. 143 IF p_flpath IS INITIAL AND p_check1 = 'X'. 144 MESSAGE e001(00) WITH 'local path can not be init'(001). 145 SET CURSOR FIELD 'P_FLPATH'. 146 ENDIF. 147 ENDIF. 148 CASE sscrfields-ucomm. 149 WHEN 'FC01'. 150 CALL SCREEN 9000. 151 WHEN OTHERS. 152 ... 153 ENDCASE. 154 *----------------------------------------------------------------------* 155 * END-OF-SELECTION 156 *----------------------------------------------------------------------* 157 END-OF-SELECTION. 158 IF w_ret = 'X'. 159 IF it_errlog IS INITIAL. 160 WRITE: /1 'Write back fail,please see error log.'(014). 161 ELSE. 162 LOOP AT it_errlog INTO iw_errlog." 163 WRITE: /1 iw_errlog-str. 164 ENDLOOP. 165 ENDIF. 166 ELSE. 167 WRITE: /1 'Write back success'(012). 168 ENDIF. 169 CLEAR:it_errlog,iw_errlog. 170 *----------------------------------------------------------------------* 171 * 子程序名称 :文件处理 172 * 子程序名 :frm_file_process 173 * 概要 :文件处理 174 * 参数 :无 175 * 返回值 :无 176 *----------------------------------------------------------------------* 177 FORM frm_file_process. 178 DATA: lw_path TYPE salfile-longname, 179 w_cmd1 TYPE string. 180 * Nonprocess路径名组成 181 CLEAR lw_path. 182 lw_path = p_fpath. 183 * 取得目录中的内容 184 PERFORM frm_read_directory TABLES it_file 185 USING lw_path 186 CHANGING w_ret. 187 IF w_ret = space. 188 * 把文件夹Nonprocess下的文件复制到文件夹Backup下 189 190 **{ Insert started by ZhouTing on 25-Jan-2015 - CR0010 191 192 ** begin of comment by zhou ting 193 ** to use open dataset instead 194 * 195 ** 这是在Linux系统下用的 196 ** CONCATENATE p_fpath cos_nonprocess cos_star2 "#EC NOTEXT 197 ** INTO w_cmd1. 198 ** 这是在windows系统下用的 199 * CONCATENATE p_fpath cos_star2 "#EC NOTEXT 200 * INTO w_cmd1. 201 * 202 ** 这是在Linux系统下用的 "need be edited 203 ** CONCATENATE 'cp' w_cmd1 p_bpath INTO w_cmd SEPARATED BY space. 204 ** 这是在windows系统下用的 205 * CONCATENATE 'copy' w_cmd1 p_bpath INTO w_cmd SEPARATED BY space. 206 ***{ Insert started by Linda on 06-Jan-2015 - CR0010 207 * TRY. 208 ***{ Insert ended by Linda on 06-Jan-2015 - CR0010 209 * CALL 'SYSTEM' ID 'COMMAND' FIELD w_cmd 210 * ID 'TAB' FIELD it_tabl-*sys*. 211 * 212 * IF sy-subrc <> 0. 213 * CONCATENATE 'Move file fail'(013) p_bpath INTO iw_errlog-str. 214 * APPEND iw_errlog TO it_errlog2. 215 * w_ret = 'X'. 216 * ENDIF. 217 ***{ Insert started by Linda on 06-Jan-2015 - CR0010 218 * CATCH cx_root. 219 * CONCATENATE 'Move file fail'(013) p_bpath INTO iw_errlog-str. 220 * APPEND iw_errlog TO it_errlog2. 221 * w_ret = 'X'. 222 * ENDTRY. 223 ***{ Insert ended by Linda on 06-Jan-2015 - CR0010 224 ** end of comment. 225 226 PERFORM frm_copy_file USING p_fpath p_bpath it_file 227 CHANGING w_ret. 228 IF w_ret <> 0. 229 CONCATENATE 'Move file fail'(013) p_bpath INTO iw_errlog-str. 230 APPEND iw_errlog TO it_errlog2. 231 w_ret = 'X'. 232 ENDIF. 233 234 **{ Insert ended by ZhouTing on 25-Jan-2015 - CR0010 235 236 * 文件数据传送接口表 237 238 PERFORM frm_transfer_data USING lw_path 239 CHANGING w_ret. 240 ENDIF. 241 242 ENDFORM. " FRM_file_process 243 *----------------------------------------------------------------------* 244 * 子程序名称 :取得目录中的内容 245 * 子程序名 :frm_read_directory 246 * 概要 :取得目录中的内容 247 * 参数 :fit_dir_bukrs type ty_dir_list 取得的目录列表 248 * :f_dir_path type salfile-longname 目录路径 249 * 返回值 :f_ret type c 正常取得:space 未取得:'1' 异常:'2' 250 *----------------------------------------------------------------------* 251 FORM frm_read_directory TABLES fit_dir TYPE ty_dir_list 252 USING f_dir_path TYPE salfile-longname 253 CHANGING f_ret TYPE c. 254 DATA: lw_lines TYPE i. 255 256 CLEAR f_ret. 257 REFRESH fit_dir. 258 CALL FUNCTION 'RZL_READ_DIR_LOCAL' 259 EXPORTING 260 name = f_dir_path 261 TABLES 262 file_tbl = fit_dir 263 EXCEPTIONS 264 argument_error = 1 265 not_found = 2 266 OTHERS = 3. 267 268 IF sy-subrc <> 0. 269 f_ret = cos_2. 270 RETURN. 271 ENDIF. 272 273 lw_lines = LINES( fit_dir ). 274 IF lw_lines < 3. 275 f_ret = cos_1. 276 ENDIF. 277 ENDFORM. " frm_read_directory 278 *----------------------------------------------------------------------* 279 * 子程序名称 :数据传输处理 280 * 子程序名 :frm_copy_file 281 * 概要 :把需处理的文件拷贝到bak目录下 282 * 参数 :i_frompath 目录路径 283 * i_topath 目录路径 284 * 返回值 :o_ret 正常:space 异常:'4' 285 *----------------------------------------------------------------------* 286 FORM frm_copy_file USING i_frompath 287 i_topath 288 i_filelist TYPE ty_dir_list 289 CHANGING o_ret. 290 291 DATA: from_file TYPE string, 292 to_file TYPE string, 293 lt_file_content TYPE TABLE OF string, 294 lv_text TYPE string, 295 ls_filelist TYPE salfldir. 296 297 LOOP AT i_filelist FROM 3 INTO ls_filelist. 298 299 REFRESH lt_file_content. 300 301 "源文件路径+文件名 302 CONCATENATE i_frompath ls_filelist-name INTO from_file. 303 "目标文件路径+文件名 304 CONCATENATE i_topath ls_filelist-name INTO to_file. 305 306 "把源文件内容保存进内表 307 OPEN DATASET from_file FOR INPUT IN TEXT MODE 308 ENCODING NON-UNICODE 309 IGNORING CONVERSION ERRORS. 310 IF sy-subrc NE 0. 311 o_ret = 4. 312 EXIT. 313 ENDIF. 314 DO. 315 READ DATASET from_file INTO lv_text. 316 IF sy-subrc NE 0. 317 EXIT. 318 ENDIF. 319 APPEND lv_text TO lt_file_content. 320 ENDDO. 321 322 CLOSE DATASET from_file. 323 324 325 "把源文件内容从系统内表中写入目标文件中 326 OPEN DATASET to_file FOR OUTPUT IN TEXT MODE 327 ENCODING NON-UNICODE 328 IGNORING CONVERSION ERRORS. 329 330 IF sy-subrc NE 0. 331 o_ret = 4. 332 EXIT. 333 ENDIF. 334 LOOP AT lt_file_content INTO lv_text. 335 TRANSFER lv_text TO to_file. 336 ENDLOOP. 337 CLOSE DATASET to_file. 338 339 ENDLOOP. 340 341 ENDFORM. "frm_copy_file 342 *----------------------------------------------------------------------* 343 * 子程序名称 :数据传输处理 344 * 子程序名 :frm_transfer_data 345 * 概要 :文件数据传送接口表 346 * 参数 :f_path type salfile-longname 目录路径 347 * 返回值 :无 348 *----------------------------------------------------------------------* 349 FORM frm_transfer_data USING f_path TYPE salfile-longname 350 CHANGING lw_ret. 351 DATA: lw_loopc TYPE sy-index, 352 lw_text(2048) TYPE c, 353 * lw_ret(1) TYPE c, 354 lw_zwrit TYPE i, 355 lw_lines TYPE i, 356 lw_len TYPE i. 357 358 * 处理文件名排序的问题 359 SORT it_file BY name DESCENDING. 360 lw_lines = LINES( it_file ). 361 lw_lines = lw_lines - 1. 362 * 删除无用的2行 363 DELETE it_file FROM lw_lines. 364 * 从it_file 取数添加到it_file2 365 366 LOOP AT it_file INTO iw_file. 367 MOVE-CORRESPONDING iw_file TO iw_file2. 368 369 lw_len = STRLEN( iw_file-name ) - 18. 370 371 SHIFT iw_file-name BY lw_len PLACES LEFT. 372 iw_file2-name2 = iw_file-name+0(14). 373 APPEND iw_file2 TO it_file2. 374 CLEAR:lw_len,iw_file2. 375 ENDLOOP. 376 377 CLEAR iw_file. 378 * 按文件生成时间排序 379 SORT it_file2 BY name2. 380 LOOP AT it_file2 INTO iw_file2. 381 * 文件路径组 382 CLEAR w_read_file. 383 CONCATENATE f_path iw_file2-name INTO w_read_file. 384 * 打开文件 385 OPEN DATASET w_read_file FOR INPUT 386 IN TEXT MODE ENCODING NON-UNICODE. 387 IF sy-subrc <> 0. 388 EXIT. 389 ENDIF. 390 DO. 391 lw_loopc = sy-index. 392 TRY. 393 CLEAR lw_text. 394 READ DATASET w_read_file INTO lw_text. 395 CATCH cx_sy_conversion_codepage. 396 CLOSE DATASET: w_read_file. 397 EXIT. 398 ENDTRY. 399 * 空文件的情况下 400 IF sy-subrc <> 0 AND lw_loopc = 1."lw_loopc = 2 带标题的文件 401 PERFORM frm_get_errno CHANGING lw_zwrit. 402 iw_err-zwrit = lw_zwrit. 403 IF p_check1 = 'X'. 404 iw_err-filen = w_lfile. 405 ELSE. 406 iw_err-filen = iw_file2-name. 407 ENDIF. 408 iw_err-errin = 'FILE NO DATA'(002). 409 iw_err-putda = w_date. 410 iw_err-putti = w_time. 411 INSERT zc0000sdt0020 FROM iw_err. 412 CLEAR:iw_err. 413 lw_ret = 'X'. 414 " EXIT. 415 ELSEIF sy-subrc <> 0. 416 **{ Insert started by ZhouTing on 30-Jan-2015 - CR0010 417 "lw_ret = 'X'. 418 **{ Insert ended by ZhouTing on 30-Jan-2015 - CR0010 419 EXIT. 420 ENDIF. 421 * 第一行不是标题 422 * IF lw_loopc = 1. 423 * CONTINUE. 424 * ENDIF. 425 * 拆分数据并加入接口表 426 * 0090036259 LR 0000300713 20140525 123456 3000 427 * vbeln fkart 客户代码 金税号 428 CHECK lw_ret IS INITIAL. 429 PERFORM frm_separate_text USING lw_text 430 CHANGING lw_ret. 431 CHECK lw_ret IS INITIAL. 432 PERFORM frm_writeback CHANGING lw_ret. 433 ENDDO. 434 435 **{ Insert started by ZhouTing on 27-Jan-2015 - CR0010 436 CLOSE DATASET w_read_file. 437 **{ Insert ended by ZhouTing on 27-Jan-2015 - CR0010 438 439 DELETE DATASET w_read_file. 440 441 ENDLOOP. 442 ENDFORM. " frm_transfer_data 443 *----------------------------------------------------------------------* 444 * 子程序名称 :拆分数据并加入接口表 445 * 子程序名 :frm_separate_text 446 * 概要 :拆分数据并加入接口表 447 * 参数 :f_text type c 要拆分的数据 448 * 返回值 :无 449 *----------------------------------------------------------------------* 450 FORM frm_separate_text USING f_text TYPE c 451 CHANGING f_ret TYPE c. 452 DATA: lw_value(100) TYPE c, 453 lw_val(1024) TYPE c, 454 lw_ret TYPE char1, 455 lw_zwrit TYPE i. 456 CLEAR f_ret. 457 lw_val = f_text. 458 459 * Sys_Inv_No 460 SPLIT lw_val AT cl_abap_char_utilities=>horizontal_tab 461 INTO lw_value lw_val. 462 IF lw_value = space. 463 * 检查 发票号是否为空 464 PERFORM frm_get_errno CHANGING lw_zwrit. 465 iw_err-zwrit = lw_zwrit. 466 IF p_check1 = 'X'. 467 iw_err-filen = w_lfile. 468 ELSE. 469 iw_err-filen = iw_file2-name. 470 ENDIF. 471 iw_err-errin = 'INVOICENO IS EMPTY'(003). 472 iw_err-vbeln = lw_value. 473 iw_err-putda = w_date. 474 iw_err-putti = w_time. 475 INSERT zc0000sdt0020 FROM iw_err. 476 CLEAR:iw_err. 477 f_ret = 'X'. 478 ELSE. 479 * Sys_Inv_No检查 480 PERFORM frm_numeric_check USING lw_value 481 CHANGING lw_ret. 482 IF lw_ret = 'X'. 483 * 检查 发票是否为数字 484 PERFORM frm_get_errno CHANGING lw_zwrit. 485 iw_err-zwrit = lw_zwrit. 486 IF p_check1 = 'X'. 487 iw_err-filen = w_lfile. 488 ELSE. 489 iw_err-filen = iw_file2-name. 490 ENDIF. 491 iw_err-errin = 'INVOICENO IS NOT NUMBER'(004). 492 iw_err-vbeln = lw_value. 493 iw_err-putda = w_date. 494 iw_err-putti = w_time. 495 INSERT zc0000sdt0020 FROM iw_err. 496 CLEAR:iw_err. 497 f_ret = 'X'. 498 ELSE. 499 * 检查 发票存在性 500 PERFORM frm_check_inv USING lw_value 501 CHANGING lw_ret. 502 IF lw_ret = 'X'. 503 PERFORM frm_get_errno CHANGING lw_zwrit. 504 iw_err-zwrit = lw_zwrit. 505 IF p_check1 = 'X'. 506 iw_err-filen = w_lfile. 507 ELSE. 508 iw_err-filen = iw_file2-name. 509 ENDIF. 510 iw_err-errin = 'INVOICENO IS NOT EXIST'(005). 511 iw_err-vbeln = lw_value. 512 iw_err-putda = w_date. 513 iw_err-putti = w_time. 514 INSERT zc0000sdt0020 FROM iw_err. 515 CLEAR:iw_err. 516 f_ret = 'X'. 517 ELSEIF lw_val = space." 金税号 为空检查 518 PERFORM frm_get_errno CHANGING lw_zwrit. 519 iw_err-zwrit = lw_zwrit. 520 IF p_check1 = 'X'. 521 iw_err-filen = w_lfile. 522 ELSE. 523 iw_err-filen = iw_file2-name. 524 ENDIF. 525 iw_err-errin = 'JINSHUHAO IS EMPTY'(006). 526 iw_err-vbeln = lw_value. 527 iw_err-putda = w_date. 528 iw_err-putti = w_time. 529 INSERT zc0000sdt0020 FROM iw_err. 530 CLEAR:iw_err. 531 f_ret = 'X'. 532 ELSE. 533 iw_ins-vbeln = lw_value. "保存 数据 534 * fkart 535 CLEAR lw_value. 536 SPLIT lw_val AT cl_abap_char_utilities=>horizontal_tab 537 INTO lw_value lw_val. 538 iw_ins-fkart = lw_value. "保存 数据 539 540 *kunrg 541 CLEAR lw_value. 542 SPLIT lw_val AT cl_abap_char_utilities=>horizontal_tab 543 INTO lw_value lw_val. 544 iw_ins-kunrg = lw_value. "保存 数据 545 * Year 546 IF lw_val = space." 年度 为空检查 547 PERFORM frm_get_errno CHANGING lw_zwrit. 548 iw_err-zwrit = lw_zwrit. 549 IF p_check1 = 'X'. 550 iw_err-filen = w_lfile. 551 ELSE. 552 iw_err-filen = iw_file2-name. 553 ENDIF. 554 iw_err-errin = 'YEAR IS EMPTY'(007). 555 iw_err-vbeln = lw_value. 556 iw_err-putda = w_date. 557 iw_err-putti = w_time. 558 INSERT zc0000sdt0020 FROM iw_err. 559 CLEAR:iw_err. 560 f_ret = 'X'. 561 ELSE. 562 CLEAR lw_value. 563 SPLIT lw_val AT cl_abap_char_utilities=>horizontal_tab 564 INTO lw_value lw_val. 565 iw_ins-gjahr = lw_value+0(4). "保存 数据 566 *linda 20140806 567 iw_ins-fkdat = lw_value. "保存 数据 568 ENDIF. 569 * VAT_Inv_No 570 CLEAR lw_value. 571 SPLIT lw_val AT cl_abap_char_utilities=>horizontal_tab 572 INTO lw_value lw_val. 573 iw_ins-xblnr = lw_value. "保存 数据 574 iw_ins-bktxt = lw_value."Linda 20140918 575 * bukrs 576 CLEAR lw_value. 577 SPLIT lw_val AT cl_abap_char_utilities=>horizontal_tab 578 INTO lw_value lw_val. 579 iw_ins-bukrs = lw_value. "保存 数据 580 ENDIF. 581 ENDIF. 582 ENDIF. 583 ENDFORM. " frm_separate_text 584 *Sys_Inv_No VAT_Inv_No VAT Issue_date Total_Amount 585 *0090035243 12345654321 2005-08-10 8 586 *----------------------------------------------------------------------* 587 * 子程序名称 :数据类型检查 588 * 子程序名 :frm_numeric_check 589 * 概要 :数据类型检查 590 * 参数 :f_val TYPE c 要检查的数据 591 * 返回值 :f_ret TYPE c 正常:space 出错:'X' 592 *----------------------------------------------------------------------* 593 FORM frm_numeric_check USING f_val TYPE c 594 CHANGING f_ret TYPE c. 595 DATA: lw_type TYPE dd01v-datatype. 596 597 CHECK f_val <> space. 598 CLEAR f_ret. 599 CALL FUNCTION 'NUMERIC_CHECK' 600 EXPORTING 601 string_in = f_val 602 IMPORTING 603 htype = lw_type. 604 IF lw_type <> cos_numc. 605 f_ret = 'X'. 606 ENDIF. 607 ENDFORM. " frm_numeric_check 608 609 *&---------------------------------------------------------------------* 610 *& Form frm_get_errno 611 *&---------------------------------------------------------------------* 612 * text 613 *----------------------------------------------------------------------* 614 * <--P_LW_ZWRIT text 615 *----------------------------------------------------------------------* 616 FORM frm_get_errno CHANGING f_zwrit TYPE i. 617 CALL FUNCTION 'NUMBER_GET_NEXT' 618 EXPORTING 619 nr_range_nr = '01' "snro 620 object = 'ZWRITEBACK' "snro object "be edit 621 IMPORTING 622 number = f_zwrit "所得到的号码 623 EXCEPTIONS 624 interval_not_found = 1 625 number_range_not_intern = 2 626 object_not_found = 3 627 quantity_is_0 = 4 628 quantity_is_not_1 = 5 629 interval_overflow = 6 630 buffer_overflow = 7 631 OTHERS = 8. 632 IF sy-subrc <> 0. 633 MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno 634 WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4 INTO iw_errlog-str. 635 APPEND iw_errlog TO it_errlog2. 636 ENDIF. 637 638 ENDFORM. " frm_get_errno 639 *&---------------------------------------------------------------------* 640 *& Form FRM_CHECK_INV 641 *&---------------------------------------------------------------------* 642 * text 643 *----------------------------------------------------------------------* 644 * -->f_vbeln text 645 * <--f_ret text 646 *----------------------------------------------------------------------* 647 FORM frm_check_inv USING f_vbeln 648 CHANGING f_ret. 649 DATA:lw_count TYPE i. 650 SELECT COUNT(*) 651 INTO lw_count 652 FROM vbrk "(Reference Document Number) 653 WHERE vbeln = f_vbeln . "Billing Document 654 IF sy-subrc = 4. 655 f_ret = 'X'. 656 ENDIF. 657 ENDFORM. " FRM_CHECK_INV 658 *&---------------------------------------------------------------------* 659 *& Form frm_writeback 660 *&---------------------------------------------------------------------* 661 * text 662 *----------------------------------------------------------------------* 663 * -->fw_ret text 664 *----------------------------------------------------------------------* 665 FORM frm_writeback CHANGING fw_ret. 666 DATA:lw_zwrit TYPE i, 667 lw_count TYPE i, 668 lw_bktxt TYPE bktxt, "linda 20140916 669 lw_belnr TYPE bkpf-belnr, 670 lw_gjahr TYPE char4. 671 *Select IsExist Invoice 672 SELECT SINGLE vbeln 673 bukrs 674 gjahr 675 xblnr 676 fkdat 677 INTO iw_vbrk 678 FROM vbrk "(Reference Document Number) 679 WHERE vbeln = iw_ins-vbeln. "Billing Document 680 IF iw_vbrk-xblnr <> iw_ins-xblnr. 681 * 将发票号更新到发票 BKPF-XBLNR(Reference Document Number) 682 PERFORM frm_vbrk_xblnr USING iw_ins-xblnr 683 iw_ins-vbeln. 684 IF w_msg_txt IS NOT INITIAL. 685 PERFORM frm_get_errno CHANGING lw_zwrit. 686 iw_err-zwrit = lw_zwrit. 687 IF p_check1 = 'X'. 688 iw_err-filen = w_lfile. 689 ELSE. 690 iw_err-filen = iw_file2-name. 691 ENDIF. 692 iw_err-errin = 'UPDATA VBRK FAIL'(008). 693 iw_err-vbeln = iw_ins-vbeln. 694 iw_err-xblnr = iw_ins-xblnr. 695 iw_err-putda = w_date. 696 iw_err-putti = w_time. 697 INSERT zc0000sdt0020 FROM iw_err. 698 CLEAR:iw_err,w_msg_txt. 699 fw_ret = 'X'. 700 ENDIF. 701 ENDIF. 702 CHECK fw_ret IS INITIAL. 703 SELECT SINGLE belnr bktxt "Linda 20140916 xblnr 704 INTO (lw_belnr,lw_bktxt) "Linda 20140916lw_xblnr 705 FROM bkpf 706 WHERE bukrs = iw_vbrk-bukrs 707 AND awkey = iw_ins-vbeln "BKPF-AWKEY(Reference Key) 708 AND gjahr = iw_vbrk-fkdat+0(4). 709 710 IF lw_bktxt <> iw_ins-bktxt. 711 lw_gjahr = iw_vbrk-fkdat+0(4). 712 IF lw_belnr IS INITIAL. 713 PERFORM frm_get_errno CHANGING lw_zwrit. 714 iw_err-zwrit = lw_zwrit. 715 IF p_check1 = 'X'. 716 iw_err-filen = w_lfile. 717 ELSE. 718 iw_err-filen = iw_file2-name. 719 ENDIF. 720 iw_err-errin = 'Invoice Is Empty'(009). 721 iw_err-vbeln = iw_ins-vbeln. 722 iw_err-xblnr = iw_ins-xblnr. 723 iw_err-putda = w_date. 724 iw_err-putti = w_time. 725 INSERT zc0000sdt0020 FROM iw_err. 726 CLEAR:iw_err,w_msg_txt. 727 fw_ret = 'X'. 728 ELSE. 729 * 将发票号更新到凭证BKPF中的BKPF-XBLNR(Reference Document Number) 730 * update the GTS No.# to BKPF-XBLNR(Reference Document Number) 731 * 2 reason:1>.要调用的function 用到了bseg这个结构; 732 * Call function "'Z_FI_ITEMS_MASS_CHANGE'" using BSEG as import structure 733 * 2>使用的频率不高,1周1次,每次XX 条,所以即使写成 select * 也对性能影响不大 734 * The call frequence will be weekly, and the volume is limited, thus should the performance impact is restricted. 735 SELECT * 736 INTO TABLE it_bseg 737 FROM bseg 738 WHERE bukrs = iw_vbrk-bukrs 739 AND belnr = lw_belnr 740 AND gjahr = lw_gjahr. 741 742 PERFORM frm_bseg_sgtxt USING iw_ins. 743 IF w_msg_txt IS NOT INITIAL. 744 PERFORM frm_get_errno CHANGING lw_zwrit. 745 iw_err-zwrit = lw_zwrit. 746 IF p_check1 = 'X'. 747 iw_err-filen = w_lfile. 748 ELSE. 749 iw_err-filen = iw_file2-name. 750 ENDIF. 751 iw_err-errin = 'BDC update fail'(010). 752 iw_err-vbeln = iw_ins-vbeln. 753 iw_err-xblnr = iw_ins-xblnr. 754 iw_err-putda = w_date. 755 iw_err-putti = w_time. 756 INSERT zc0000sdt0020 FROM iw_err. 757 CLEAR:iw_err,w_msg_txt. 758 fw_ret = 'X'. 759 ENDIF. 760 761 ENDIF. 762 ENDIF. 763 CHECK fw_ret IS INITIAL. 764 SELECT COUNT(*) 765 FROM zc0000sdt0020 766 INTO lw_count 767 WHERE vbeln = iw_ins-vbeln. 768 IF lw_count > 1. 769 DELETE FROM zc0000sdt0020 WHERE vbeln = iw_ins-vbeln. 770 IF sy-subrc = 0. 771 COMMIT WORK AND WAIT. 772 ELSE. 773 ROLLBACK WORK. 774 ENDIF. 775 ENDIF. 776 CLEAR:it_bseg. 777 ENDFORM. " frm_writeback 778 *&---------------------------------------------------------------------* 779 *& Module STATUS_9000 OUTPUT 780 *&---------------------------------------------------------------------* 781 * text 782 *----------------------------------------------------------------------* 783 MODULE status_9000 OUTPUT. 784 SET PF-STATUS '800'. 785 SET TITLEBAR 'ERROR LOG SEARCH'. 786 787 ENDMODULE. " STATUS_9000 OUTPUT 788 *&---------------------------------------------------------------------* 789 *& Module USER_COMMAND_9000 INPUT 790 *&---------------------------------------------------------------------* 791 * text 792 *----------------------------------------------------------------------* 793 MODULE user_command_9000 INPUT. 794 CASE ok_code. 795 WHEN 'EXECUTE'. 796 PERFORM frm_data_select. 797 798 IF it_errlog IS INITIAL. 799 MESSAGE e001(00) WITH 'NO error log data'(011). 800 LEAVE TO SCREEN 9000. 801 ENDIF. 802 * ALV最后结果输出 803 PERFORM frm_display_data. 804 WHEN 'CANCEL'. 805 LEAVE TO SCREEN 0. 806 WHEN 'EXIT'. 807 LEAVE PROGRAM. 808 WHEN 'BACK'. 809 LEAVE TO SCREEN 0. 810 ENDCASE. 811 ENDMODULE. " USER_COMMAND_9000 INPUT 812 *----------------------------------------------------------------------* 813 * 子程序名称 :ALV最后结果输出 814 * 子程序名 :frm_display_data 815 * 概要 :ALV最后结果输出 816 * 参数 :无 817 * 返回值 :无 818 *----------------------------------------------------------------------* 819 FORM frm_display_data . 820 w_repid = sy-repid. 821 CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY' 822 EXPORTING 823 i_callback_program = w_repid 824 i_structure_name = 'ZC0000SDT0020' 825 it_fieldcat = it_fieldcat 826 TABLES 827 t_outtab = it_errlog. 828 IF sy-subrc <> 0. 829 * MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO 830 * WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4. 831 ENDIF. 832 833 ENDFORM. " frm_display_data 834 *&---------------------------------------------------------------------* 835 *& Form frm_data_select 836 *&---------------------------------------------------------------------* 837 * text 838 *----------------------------------------------------------------------* 839 * --> p1 text 840 * <-- p2 text 841 *----------------------------------------------------------------------* 842 FORM frm_data_select . 843 IF zc0000sdt0020-filen IS NOT INITIAL. 844 CONCATENATE 'FILEN LIKE ''' zc0000sdt0020-filen '%''' INTO w_str. 845 ENDIF. 846 **************** putda************************************** 847 IF zc0000sdt0020-putda IS NOT INITIAL AND putdahigh IS INITIAL. 848 IF w_str IS NOT INITIAL. 849 CONCATENATE w_str ' and putda = ZC0000SDT0020-putda' INTO w_str. 850 ELSE. 851 w_str = 'putda = ZC0000SDT0020-putda'. 852 ENDIF. 853 ENDIF. 854 IF zc0000sdt0020-putda IS INITIAL AND putdahigh IS NOT INITIAL. 855 IF w_str IS NOT INITIAL. 856 CONCATENATE w_str ' and putda = putdahigh' INTO w_str. 857 ELSE. 858 w_str = 'putda = putdahigh'. 859 ENDIF. 860 ENDIF. 861 IF zc0000sdt0020-putda IS NOT INITIAL AND putdahigh IS NOT INITIAL. 862 IF w_str IS NOT INITIAL. 863 CONCATENATE w_str ' and putda <= putdahigh and putda >= ZC0000SDT0020-putda' INTO w_str. 864 ELSE. 865 w_str = 'putda <= putdahigh and putda >= ZC0000SDT0020-putda'. 866 ENDIF. 867 868 ENDIF. 869 * **************** putti************************************** 870 IF zc0000sdt0020-putti IS NOT INITIAL AND puttihigh IS INITIAL. 871 IF w_str IS NOT INITIAL. 872 CONCATENATE w_str ' and putti = ZC0000SDT0020-putti' INTO w_str. 873 ELSE. 874 w_str = 'putti = ZC0000SDT0020-putti'. 875 ENDIF. 876 ENDIF. 877 IF zc0000sdt0020-putti IS INITIAL AND puttihigh IS NOT INITIAL. 878 IF w_str IS NOT INITIAL. 879 CONCATENATE w_str ' and putti = puttihigh' INTO w_str. 880 ELSE. 881 w_str = 'putti = puttihigh'. 882 ENDIF. 883 ENDIF. 884 IF zc0000sdt0020-putti IS NOT INITIAL AND puttihigh IS NOT INITIAL. 885 IF w_str IS NOT INITIAL. 886 CONCATENATE w_str ' and putti <= puttihigh and putti >= ZC0000SDT0020-putti' INTO w_str. 887 ELSE. 888 w_str = 'putti <= puttihigh and putti >= ZC0000SDT0020-putti'. 889 ENDIF. 890 891 ENDIF. 892 * **************** VBELN************************************** 893 IF zc0000sdt0020-vbeln IS NOT INITIAL AND vbelnhigh IS INITIAL. 894 IF w_str IS NOT INITIAL. 895 CONCATENATE w_str ' and VBELN = ZC0000SDT0020-VBELN' INTO w_str. 896 ELSE. 897 w_str = 'VBELN = ZC0000SDT0020-VBELN'. 898 ENDIF. 899 ENDIF. 900 IF zc0000sdt0020-vbeln IS INITIAL AND vbelnhigh IS NOT INITIAL. 901 IF w_str IS NOT INITIAL. 902 CONCATENATE w_str ' and VBELN = VBELNHIGH' INTO w_str. 903 ELSE. 904 w_str = 'VBELN = VBELNHIGH'. 905 ENDIF. 906 ENDIF. 907 IF zc0000sdt0020-vbeln IS NOT INITIAL AND vbelnhigh IS NOT INITIAL. 908 IF w_str IS NOT INITIAL. 909 CONCATENATE w_str ' and VBELN <= VBELNHIGH and VBELN >= ZC0000SDT0020-VBELN' INTO w_str. 910 ELSE. 911 w_str = 'VBELN <= VBELNHIGH and VBELN >= ZC0000SDT0020-VBELN'. 912 ENDIF. 913 914 ENDIF. 915 * **************** XBLNR************************************** 916 IF zc0000sdt0020-xblnr IS NOT INITIAL AND xblnrhigh IS INITIAL. 917 IF w_str IS NOT INITIAL. 918 CONCATENATE w_str ' and XBLNR = ZC0000SDT0020-XBLNR' INTO w_str. 919 ELSE. 920 w_str = 'XBLNR = ZC0000SDT0020-XBLNR'. 921 ENDIF. 922 ENDIF. 923 IF zc0000sdt0020-xblnr IS INITIAL AND xblnrhigh IS NOT INITIAL. 924 IF w_str IS NOT INITIAL. 925 CONCATENATE w_str ' and XBLNR = XBLNRHIGH' INTO w_str. 926 ELSE. 927 w_str = 'XBLNR = XBLNRHIGH'. 928 ENDIF. 929 ENDIF. 930 IF zc0000sdt0020-xblnr IS NOT INITIAL AND xblnrhigh IS NOT INITIAL. 931 IF w_str IS NOT INITIAL. 932 CONCATENATE w_str ' and XBLNR <= XBLNRHIGH and XBLNR >= ZC0000SDT0020-XBLNR' INTO w_str. 933 ELSE. 934 w_str = 'XBLNR <= XBLNRHIGH and XBLNR >= ZC0000SDT0020-XBLNR'. 935 ENDIF. 936 937 ENDIF. 938 * **************** ERRIN************************************** 939 IF zc0000sdt0020-errin IS NOT INITIAL. 940 IF w_str IS NOT INITIAL. 941 CONCATENATE w_str ' and ERRIN LIKE ''' zc0000sdt0020-errin '%''' INTO w_str. 942 ELSE. 943 CONCATENATE 'ERRIN LIKE ''' zc0000sdt0020-errin '%''' INTO w_str. 944 ENDIF. 945 ENDIF. 946 SELECT zwrit 947 filen 948 putda 949 putti 950 vbeln 951 xblnr 952 errin 953 INTO CORRESPONDING FIELDS OF TABLE it_errlog 954 FROM zc0000sdt0020 955 WHERE (w_str). 956 CLEAR:w_str. 957 ENDFORM. " frm_data_select 958 *&---------------------------------------------------------------------* 959 *& Form frm_vbrk_xblnr 960 *&---------------------------------------------------------------------* 961 * text 962 *----------------------------------------------------------------------* 963 * -->pf_xblnr text 964 * -->pf_vbeln text 965 *----------------------------------------------------------------------* 966 FORM frm_vbrk_xblnr USING pf_xblnr 967 pf_vbeln. 968 969 CALL FUNCTION 'UPDATE_XBLNR_IN_VBRK' 970 EXPORTING 971 i_vbeln = pf_vbeln 972 i_xblnr = pf_xblnr 973 * I_XBLNR_CHECK = 974 * IMPORTING 975 * E_XBLNR = 976 EXCEPTIONS 977 document_blocked = 1 978 update_no_success = 2 979 OTHERS = 3 980 . 981 IF sy-subrc <> 0. 982 MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno 983 INTO w_msg_txt 984 WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4. 985 ENDIF. 986 987 ENDFORM. " FRM_VBRK_BDC 988 *&---------------------------------------------------------------------* 989 *& Form FRM_FILE_PROCESS_LOCAL 990 *&---------------------------------------------------------------------* 991 * text 992 *----------------------------------------------------------------------* 993 * --> p1 text 994 * <-- p2 text 995 *----------------------------------------------------------------------* 996 FORM frm_file_process_local. 997 DATA: ls_row TYPE kcdu_srec, 998 lw_zwrit TYPE i. 999 1000 PERFORM file_format_check. 1001 PERFORM upload_csv. 1002 1003 * 文件数据传送接口表 1004 DO. 1005 w_row_num = sy-index. 1006 CLEAR ls_row. 1007 " w_step_ok = 'X'. 1008 CALL FUNCTION 'FILE_NEXT_RECORD' 1009 IMPORTING 1010 next_record = ls_row 1011 EXCEPTIONS 1012 no_record = 1. 1013 IF sy-subrc <> 0 OR ls_row IS INITIAL. 1014 IF w_row_num = 1. 1015 PERFORM frm_get_errno CHANGING lw_zwrit. 1016 iw_err-zwrit = lw_zwrit. 1017 iw_err-filen = w_lfile. 1018 iw_err-errin = 'FILE NO DATA'(002). 1019 iw_err-putda = w_date. 1020 iw_err-putti = w_time. 1021 INSERT zc0000sdt0020 FROM iw_err. 1022 CLEAR:iw_err. 1023 w_ret = 'X'. 1024 ENDIF. 1025 EXIT. 1026 ENDIF. 1027 1028 * 第一行不是标题 1029 * IF lw_loopc = 1. 1030 * CONTINUE. 1031 * ENDIF. 1032 * 拆分数据并加入接口表 1033 * 0090036259 LR 0000300713 20140525 123456 3000 1034 * vbeln fkart 客户代码 金税号 1035 CHECK w_ret IS INITIAL. 1036 PERFORM frm_separate_text USING ls_row 1037 CHANGING w_ret. 1038 CHECK w_ret IS INITIAL. 1039 PERFORM frm_writeback CHANGING w_ret. 1040 1041 ENDDO. 1042 1043 ENDFORM. " frm_file_process_local 1044 *&---------------------------------------------------------------------* 1045 *& Form form_get_file_path_upload 1046 *&---------------------------------------------------------------------* 1047 * text 1048 *----------------------------------------------------------------------* 1049 * --> p1 text 1050 * <-- p2 text 1051 *----------------------------------------------------------------------* 1052 FORM form_get_file_path_upload . 1053 DATA: 1054 ld_rc TYPE i, 1055 lw_file TYPE string, 1056 lt_file TYPE filetable. 1057 1058 CALL FUNCTION 'GET_DYNP_VALUE' 1059 EXPORTING 1060 i_field = 'P_FLPATH' 1061 i_repid = sy-repid 1062 i_dynnr = '1000' 1063 CHANGING 1064 o_value = p_flpath. 1065 1066 lw_file = p_flpath. 1067 1068 CALL FUNCTION 'CH_SPLIT_FILENAME' 1069 EXPORTING 1070 complete_filename = lw_file 1071 IMPORTING 1072 path = w_file_path 1073 EXCEPTIONS 1074 invalid_drive = 1 1075 invalid_path = 2 1076 OTHERS = 3. 1077 1078 CALL METHOD cl_gui_frontend_services=>file_open_dialog 1079 EXPORTING 1080 * window_title = 1081 default_extension = '*.TXT' 1082 default_filename = lw_file 1083 file_filter = '*.TXT' 1084 * with_encoding = 1085 initial_directory = w_file_path 1086 * multiselection = 1087 CHANGING 1088 file_table = lt_file 1089 rc = ld_rc 1090 * user_action = 1091 * file_encoding = 1092 EXCEPTIONS 1093 file_open_dialog_failed = 1 1094 cntl_error = 2 1095 error_no_gui = 3 1096 not_supported_by_gui = 4 1097 OTHERS = 5. 1098 IF sy-subrc <> 0. 1099 MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno 1100 WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4. 1101 ELSE. 1102 READ TABLE lt_file INTO lw_file INDEX 1. 1103 p_flpath = lw_file. 1104 ENDIF. 1105 1106 ENDFORM. " form_get_file_path_upload 1107 1108 *&---------------------------------------------------------------------* 1109 *& Form file_format_check 1110 *&---------------------------------------------------------------------* 1111 * text 1112 *----------------------------------------------------------------------* 1113 * --> p1 text 1114 * <-- p2 text 1115 *----------------------------------------------------------------------* 1116 FORM file_format_check . 1117 DATA:ld_ext TYPE char10, 1118 lw_file TYPE string, 1119 lw_name TYPE string. 1120 lw_file = p_flpath. 1121 CALL FUNCTION 'CH_SPLIT_FILENAME' 1122 EXPORTING 1123 complete_filename = lw_file 1124 IMPORTING 1125 extension = ld_ext 1126 name = lw_name 1127 name_with_ext = w_lfile 1128 EXCEPTIONS 1129 invalid_drive = 1 1130 invalid_path = 2 1131 OTHERS = 3. 1132 IF sy-subrc <> 0. 1133 MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno 1134 WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4 INTO iw_errlog-str. 1135 APPEND iw_errlog TO it_errlog2. 1136 w_ret = 'X'. 1137 ENDIF. 1138 1139 IF sy-subrc <> 0. 1140 MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno 1141 WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4. 1142 ELSE. 1143 CALL FUNCTION 'AIPC_CONVERT_TO_UPPERCASE' 1144 EXPORTING 1145 i_input = ld_ext 1146 i_langu = sy-langu 1147 IMPORTING 1148 e_output = ld_ext. 1149 ENDIF. 1150 ENDFORM. " file_format_check 1151 *&---------------------------------------------------------------------* 1152 *& Form upload_csv 1153 *&---------------------------------------------------------------------* 1154 * text 1155 *----------------------------------------------------------------------* 1156 * --> p1 text 1157 * <-- p2 text 1158 *----------------------------------------------------------------------* 1159 FORM upload_csv . 1160 DATA:ld_file TYPE localfile. 1161 1162 ld_file = p_flpath. 1163 1164 CALL FUNCTION 'FILE_OPEN' 1165 EXPORTING 1166 filnm = ld_file 1167 upl = 'X' 1168 filfmt = 'T' 1169 EXCEPTIONS 1170 logname_not_found = 1 1171 file_not_opened = 2 1172 OTHERS = 3. 1173 IF sy-subrc <> 0. 1174 MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno 1175 WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4 INTO iw_errlog-str. 1176 APPEND iw_errlog TO it_errlog2. 1177 w_ret = 'X'. 1178 ENDIF. 1179 ENDFORM. " upload_csv 1180 *&---------------------------------------------------------------------* 1181 *& Form FRM_BSEG_UPDATE 1182 *&---------------------------------------------------------------------* 1183 * text 1184 *----------------------------------------------------------------------* 1185 * -->pf_bukrs text 1186 * -->pf_belnr text 1187 * -->pf_gjahr text 1188 * -->pf_buzei text 1189 * -->pf_bschl text 1190 * -->pf_bktxt text 1191 *----------------------------------------------------------------------* 1192 FORM frm_bseg_update USING pf_bukrs 1193 pf_belnr 1194 pf_gjahr 1195 pf_buzei 1196 pf_bschl 1197 pf_bktxt. "Linda 20141117 1198 DATA:iw_buztab TYPE tpit_buztab, 1199 iw_fldtab TYPE tpit_fname. 1200 1201 * 所改字段之值 1202 * iw_bseg-sgtxt = pf_sgtxt. "Linda 20141117 edi 1203 iw_bseg-sgtxt = pf_bktxt. 1204 1205 iw_buztab-bukrs = pf_bukrs. 1206 iw_buztab-belnr = pf_belnr. 1207 iw_buztab-gjahr = pf_gjahr. 1208 iw_buztab-buzei = pf_buzei. 1209 iw_buztab-bschl = pf_bschl. "posting key 1210 * it_buztab-koart = 'S'. "leixing 1211 APPEND iw_buztab TO it_buztab. 1212 1213 iw_fldtab-fname = 'SGTXT'. 1214 iw_fldtab-aenkz = 'X'. 1215 APPEND iw_fldtab TO it_fldtab. 1216 1217 * copy from FI_ITEMS_MASS_CHANGE , change defult module from asynchronous to synchronous 1218 CALL FUNCTION 'Z_FI_ITEMS_MASS_CHANGE' 1219 EXPORTING 1220 s_bseg = iw_bseg 1221 i_bktxt = pf_bktxt 1222 IMPORTING 1223 errtab = it_errtab 1224 TABLES 1225 it_buztab = it_buztab 1226 it_fldtab = it_fldtab 1227 EXCEPTIONS 1228 bdc_errors = 1 1229 OTHERS = 2. 1230 IF sy-subrc = 0. 1231 COMMIT WORK AND WAIT. 1232 ELSE. 1233 MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno 1234 WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4 INTO w_msg_txt. 1235 ENDIF. 1236 CLEAR:it_errtab,it_errtab[],it_buztab,it_buztab[],it_fldtab,it_fldtab[],iw_bseg. 1237 1238 ENDFORM. " FRM_BSEG_UPDATE 1239 *&---------------------------------------------------------------------* 1240 *& Form FRM_BSEG_SGTXT 1241 *&---------------------------------------------------------------------* 1242 * text 1243 *----------------------------------------------------------------------* 1244 * --> pf_ins text 1245 *----------------------------------------------------------------------* 1246 FORM frm_bseg_sgtxt USING pf_ins LIKE iw_ins. 1247 DATA:lw_bseg TYPE bseg. 1248 LOOP AT it_bseg INTO lw_bseg. 1249 1250 PERFORM frm_bseg_update USING lw_bseg-bukrs 1251 lw_bseg-belnr 1252 lw_bseg-gjahr 1253 lw_bseg-buzei 1254 lw_bseg-bschl 1255 pf_ins-bktxt. 1256 IF w_msg_txt IS NOT INITIAL. 1257 EXIT. 1258 ENDIF. 1259 ENDLOOP. 1260 ENDFORM. " FRM_BSEG_SGTXT
本文来自博客园,作者:Slashout,转载请注明原文链接:https://www.cnblogs.com/SlashOut/p/4996882.html