2020-10-20
ABAP und der SAP NetWeaver Core hatten lange Zeit Probleme, moderne Funktionen wie die Interaktion mit MS Excel-Dateiformaten anzubieten. Es ist jedoch leicht möglich, Daten aus einer Excel-Datei in SAP ABAP zu lesen. So geht's.
Sind Sie neu in der SAP-Welt und möchten schnell mitreden? Mit diesem Buch finden Sie sich erfolgreich im SAP-Umfeld zurecht! Sie steigen direkt in die Konzepte und Technologien der SAP-Software ein und lernen die unterschiedlichen Systeme und Prozesse kennen. Schritt für Schritt zeigen die Autoren Ihnen die wichtigsten technischen Aufgaben und die Zusammenhänge zwischen den Objekten. Dank der vielen Beispiele und Abbildungen finden Sie sich schnell im SAP-Umfeld zurecht und können direkt in SAP ERP oder SAP S/4HANA anfangen.
Bei amazon.de ansehen →Der Schlüssel zum Lesen von Excel-Dateien in ABAP ist die Funktion zif_excel_reader in Verbindung mit der Klasse zcl_excel_reader_2007. Mit diesen ABAP-Tools erhalten Sie Zugriff auf eine Reihe von Methoden und Funktionen zum einfachen Lesen von Daten aus XLS- und XLSX-Dateiformaten. Dies ist sehr hilfreich, wenn Sie Daten aus Excel in SAP importieren oder Ihren SAP-Benutzern benutzerfreundliche Services anbieten wollen.
PARAMETERS pa_funcname TYPE file_table-filename OBLIGATORY. * This selection screen event is fired when the F4 help for field pa_funcname is called. AT SELECTION-SCREEN ON VALUE-REQUEST FOR pa_funcname. DATA lv_return TYPE i. DATA lv_user_action TYPE i. DATA it_filetable TYPE filetable. * Clear file table. It might contain old entries from earlier calls. CLEAR it_filetable. * Call the "open file" dialog. TRY. cl_gui_frontend_services=>file_open_dialog( EXPORTING file_filter = |xls (*.xls)\|*.xls\|{ cl_gui_frontend_services=>filetype_all }| multiselection = abap_false CHANGING file_table = it_filetable rc = lv_return user_action = lv_user_action ). IF lv_user_action EQ cl_gui_frontend_services=>action_ok. IF lines( it_filetable ) > 0. * Check the first entry pa_funcname = it_filetable[1]-filename. ENDIF. ENDIF. CATCH cx_root INTO DATA(e_error_message). MESSAGE e_error_message->get_text( ) TYPE 'I'. ENDTRY. * When the report is submitted... START-OF-SELECTION. TRY. * Create a reader object DATA(lo_excel_reader) = CAST zif_excel_reader( NEW zcl_excel_reader_2007( ) ). DATA(lo_excel_file) = lo_excel_reader->load_file( pa_funcname ). * This reads the active worksheet from the excel file DATA(lo_active_sheet) = lo_excel_file->get_active_worksheet( ). * Output the content of the active sheet LOOP AT lo_active_sheet->sheet_content ASSIGNING FIELD-SYMBOL(<cell>) GROUP BY <cell>-cell_row ASSIGNING FIELD-SYMBOL(<row>). LOOP AT GROUP <row> ASSIGNING FIELD-SYMBOL(<cell_data>). * Here are some examples of the data you can get. WRITE: / <cell_data>-cell_coords, <cell_data>-cell_value, <cell_data>-cell_formula, <cell_data>-data_type, <cell_data>-cell_column, <cell_data>-cell_row, <cell_data>-cell_style. ENDLOOP. ENDLOOP. CATCH cx_root INTO DATA(e_error_message). WRITE: / e_error_message->get_text( ). ENDTRY.