types:Подробнее...
begin of vrm_value,
key(40) type c,
text(80) type c,
end of vrm_value,
VRM_VALUES TYPE VRM_VALUE OCCURS 0.
data: lifnr_values TYPE VRM_VALUES with header line.
FREE lifnr_values. " обязательно
data: lfa1_tb TYPE WSTN_LFA1_TAB, lfa1_ln TYPE LFA1.
" заполнить где-то lfa1_tb поставщиками
LOOP AT lfa1_tb into lfa1_ln.
lifnr_values-key = lfa1_ln-lifnr.
CONCATENATE lfa1_ln-NAME1 lfa1_ln-NAME2 lfa1_ln-NAME3 lfa1_ln-NAME4
into lifnr_values-text.
APPEND lifnr_values.
ENDLOOP.
call function 'VRM_SET_VALUES'
EXPORTING
id = 'LIFNR' " имя элемента
values = lifnr_values[]
EXCEPTIONS
others = 1.
Сюда я буду сохранять всякие куски кода, конфигов, ссылки, чтобы в один прекрасный день когда мне это снова понадобится - не вспоминать судорожно где и когда я это применял.
28 апреля 2011 г.
Заполнение списка предлагаемых значений Listbox-а
На примере списка кредиторов
Sap Scripting
Проблема: необходимо автоматически запустить sap logon и выполнить какие-то действия автоматически.
1. Необходимо активировать у инстанции возможность Sap scripting-а
http://searchsap.techtarget.com/feature/Step-2-Activating-SAPGUI-scripting
2. Как генерировать скориптинг
Настройка локального формата .Запись и воспроизведение скрипта. Дальше там понятно что делать.
3. Пример скрипта:
Подробнее...
1. Необходимо активировать у инстанции возможность Sap scripting-а
http://searchsap.techtarget.com/feature/Step-2-Activating-SAPGUI-scripting
2. Как генерировать скориптинг
Настройка локального формата .Запись и воспроизведение скрипта. Дальше там понятно что делать.
3. Пример скрипта:
dim session
StartApp
if WScript.Arguments.Count > 0 Then
if WScript.Arguments(0) = "Site" Then
SiteUpload
End if
End if
rem Выходим
session.findById("wnd[0]/tbar[0]/okcd").text = "/nex"
session.findById("wnd[0]").sendVKey 0
Sub SiteUpload
rem Запускаем программу
session.findById("wnd[0]/tbar[0]/okcd").text = "se38"
session.findById("wnd[0]").sendVKey 0
session.findById("wnd[0]/usr/ctxtRS38M-PROGRAMM").text = "ZRSITE_UPLOAD"
session.findById("wnd[0]").sendVKey 8
session.findById("wnd[0]/usr/txtTUNE").text = "tyumen"
session.findById("wnd[0]/usr/txtMIN_C").text = "15"
session.findById("wnd[0]/usr/txtTEMP_DIR").text = "C:\"
session.findById("wnd[0]/usr/txtPR_VARI").text = "TYUMEN"
session.findById("wnd[0]").sendVKey 8
end sub
rem Подпрограма запуска приложения
Sub StartApp
rem запускаем саплогон
Set WshShell = CreateObject("WScript.Shell")
WshShell.Run "C:\Progra~1\SAP\FrontEnd\SAPgui\saplogon.exe", 1, False
rem ждём открытия
WScript.Sleep(10000)
rem Открываеем сессию
If Not IsObject(application) Then
Set SapGuiAuto = GetObject("SAPGUI")
Set application = SapGuiAuto.GetScriptingEngine
rem application.OpenConnection("RD1")
application.OpenConnectionByConnectionString("rosasap09 00")
Set connection = application.Children(application.Children.Count - 1) rem свежеоткртое окно
Set session = connection.Children(0)
End If
If IsObject(WScript) Then
WScript.ConnectObject session, "on"
WScript.ConnectObject application, "on"
End If
rem Авторизация
session.findById("wnd[0]").maximize
session.findById("wnd[0]/usr/txtRSYST-MANDT").text = "800"
session.findById("wnd[0]/usr/txtRSYST-BNAME").text = "alexeys"
session.findById("wnd[0]/usr/pwdRSYST-BCODE").text = ""
session.findById("wnd[0]/usr/txtRSYST-LANGU").text = "ru"
session.findById("wnd[0]").sendVKey 0
rem Если открылось окно, что чувак уже залогинен - закрыть? а может не закрывать? Тогда вместо OPT1 - OPT2
set log_opt = session.findById("wnd[1]/usr/radMULTI_LOGON_OPT1", False)
If not log_opt Is Nothing Then
log_opt.select
session.findById("wnd[1]/tbar[0]/btn[0]").press
End If
End Sub
Подробнее...
Вызов PBO из событий ALV
Проблема: в событии ALV изменились какие-либо значения, отображаемые экраном DynPro, но так как события PBO не было - пользователь видит старые значения.
Подобрал два варианта:
1. Имитировать событие PBO.
Работает, но медленно. Возможно если использовать другой FUNCTIONCODE, будет лучше. знак равенства предлагался как значение по умолчанию.
2. Обновить значение самостоятельно.
Пробовал использовать функции DYNP_VALUES_READ и DYNP_VALUES_UPDATE, но не получилось. зато получилось с
Работает, быстро, но есть казусы (возможно имеют решения, но я пока их не знаю):
- иногда теряются часть текста после переключения закладок с этими данными.
- не получилось использовать для чисел - пришлось менять тип на текстовый, что не всегда допустимо.
- пришлось отказаться от программ преобразования - вызываю их сам в коде, что тоже не всегда удобно.
3. У конструктора ALV GRID-а есть параметр i_appl_events. если его взвести - при нажатии вызывается PAI, а после PBO. Но тоже медленно всё работает. Возможно у других объектов есть такой же способ.
4. cl_gui_cfw=>set_new_ok_code. Тоже медленно.
CALL METHOD cl_gui_cfw=>set_new_ok_code
EXPORTING
new_code = 'DUMMY'.
CL_GUI_CFW=>FLUSH. Подробнее...
Подобрал два варианта:
1. Имитировать событие PBO.
CALL FUNCTION 'SAPGUI_SET_FUNCTIONCODE'EXPORTINGFUNCTIONCODE = '='EXCEPTIONSFUNCTION_NOT_SUPPORTED = 1OTHERS = 2.
Работает, но медленно. Возможно если использовать другой FUNCTIONCODE, будет лучше. знак равенства предлагался как значение по умолчанию.
2. Обновить значение самостоятельно.
Пробовал использовать функции DYNP_VALUES_READ и DYNP_VALUES_UPDATE, но не получилось. зато получилось с
DATA: dynpfields_tb TYPE TABLE OF dynpread,
dynpfields_ln TYPE dynpread.
DEFINE AddField.
dynpfields_ln-fieldname = '&1'.
dynpfields_ln-fieldvalue = &1.
APPEND dynpfields_ln to dynpfields_tb.
END-OF-DEFINITION.
AddField MAT_INFO_STR-MATNR.
AddField MAT_INFO_STR-MATERIAL_NAME.
CALL FUNCTION 'DYNP_UPDATE_FIELDS'
EXPORTING
DYNAME = sy-repid
DYNUMB = '1210'
TABLES
DYNPFIELDS = dynpfields_tb
EXCEPTIONS
INVALID_ABAPWORKAREA = 1
INVALID_DYNPROFIELD = 2
INVALID_DYNPRONAME = 3
INVALID_DYNPRONUMMER = 4
INVALID_REQUEST = 5
NO_FIELDDESCRIPTION = 6
UNDEFIND_ERROR = 7
OTHERS = 8.
Работает, быстро, но есть казусы (возможно имеют решения, но я пока их не знаю):
- иногда теряются часть текста после переключения закладок с этими данными.
- не получилось использовать для чисел - пришлось менять тип на текстовый, что не всегда допустимо.
- пришлось отказаться от программ преобразования - вызываю их сам в коде, что тоже не всегда удобно.
3. У конструктора ALV GRID-а есть параметр i_appl_events. если его взвести - при нажатии вызывается PAI, а после PBO. Но тоже медленно всё работает. Возможно у других объектов есть такой же способ.
4. cl_gui_cfw=>set_new_ok_code. Тоже медленно.
CALL METHOD cl_gui_cfw=>set_new_ok_code
EXPORTING
new_code = 'DUMMY'.
CL_GUI_CFW=>FLUSH. Подробнее...
27 апреля 2011 г.
ABAP: добавление своей кнопки в TOOLBAR ALV GRID
Для этого надо создать класс обработчик для обработки событий toolbar и user_command для ALV GRID.
Пример:
CLASS cl_trans_g_event_receiver DEFINITION.
PUBLIC SECTION.
METHODS:
handle_toolbar
FOR EVENT toolbar OF cl_gui_alv_grid
IMPORTING e_object e_interactive,
handle_user_command
FOR EVENT user_command OF cl_gui_alv_grid
IMPORTING e_ucomm.
ENDCLASS.
CLASS cl_trans_g_event_receiver IMPLEMENTATION.
METHOD handle_toolbar.
PERFORM method_trans_toolbar USING e_object.
ENDMETHOD.
METHOD handle_user_command.
PERFORM method_trans_user_command USING e_ucomm.
ENDMETHOD.
ENDCLASS.
* Добавление кнопки в тулбар
FORM METHOD_TRANS_TOOLBAR USING P_E_OBJECT TYPE REF TO CL_ALV_EVENT_TOOLBAR_SET.
DATA: ty_toolbar TYPE stb_button.
* разделитель
CLEAR ty_toolbar.
ty_toolbar-butn_type = 3.
APPEND ty_toolbar TO p_e_object->mt_toolbar.
* кнопка
CLEAR ty_toolbar.
ty_toolbar-function = 'MYBUTT'.
ty_toolbar-icon = ICON_HISTORY.
ty_toolbar-butn_type = 0.
ty_toolbar-text = 'Моя кнопка'.
APPEND ty_toolbar TO p_e_object->mt_toolbar.
ENDFORM.
* Обработка команд
FORM METHOD_TRANS_USER_COMMAND USING P_E_UCOMM TYPE SY-UCOMM.
CASE p_e_ucomm.
WHEN 'MYBUTT'.
* ЧТО-ТО ДЕЛАЕМ
ENDCASE.
ENDFORM.
Ну и надо незабыть инициализировать все это после создания грида:
DATA: trans_g_event_receiver TYPE REF TO cl_trans_g_event_receiver.
CREATE OBJECT trans_g_event_receiver.
SET HANDLER trans_g_event_receiver->handle_toolbar FOR trans_grid.
SET HANDLER trans_g_event_receiver->handle_user_command FOR trans_grid. Подробнее...
Пример:
CLASS cl_trans_g_event_receiver DEFINITION.
PUBLIC SECTION.
METHODS:
handle_toolbar
FOR EVENT toolbar OF cl_gui_alv_grid
IMPORTING e_object e_interactive,
handle_user_command
FOR EVENT user_command OF cl_gui_alv_grid
IMPORTING e_ucomm.
ENDCLASS.
CLASS cl_trans_g_event_receiver IMPLEMENTATION.
METHOD handle_toolbar.
PERFORM method_trans_toolbar USING e_object.
ENDMETHOD.
METHOD handle_user_command.
PERFORM method_trans_user_command USING e_ucomm.
ENDMETHOD.
ENDCLASS.
* Добавление кнопки в тулбар
FORM METHOD_TRANS_TOOLBAR USING P_E_OBJECT TYPE REF TO CL_ALV_EVENT_TOOLBAR_SET.
DATA: ty_toolbar TYPE stb_button.
* разделитель
CLEAR ty_toolbar.
ty_toolbar-butn_type = 3.
APPEND ty_toolbar TO p_e_object->mt_toolbar.
* кнопка
CLEAR ty_toolbar.
ty_toolbar-function = 'MYBUTT'.
ty_toolbar-icon = ICON_HISTORY.
ty_toolbar-butn_type = 0.
ty_toolbar-text = 'Моя кнопка'.
APPEND ty_toolbar TO p_e_object->mt_toolbar.
ENDFORM.
* Обработка команд
FORM METHOD_TRANS_USER_COMMAND USING P_E_UCOMM TYPE SY-UCOMM.
CASE p_e_ucomm.
WHEN 'MYBUTT'.
* ЧТО-ТО ДЕЛАЕМ
ENDCASE.
ENDFORM.
Ну и надо незабыть инициализировать все это после создания грида:
DATA: trans_g_event_receiver TYPE REF TO cl_trans_g_event_receiver.
CREATE OBJECT trans_g_event_receiver.
SET HANDLER trans_g_event_receiver->handle_toolbar FOR trans_grid.
SET HANDLER trans_g_event_receiver->handle_user_command FOR trans_grid. Подробнее...
ABAP: стили ячеек в ALV GRID.
Список возможных значений стилей можно или даже нужно брать из инклуда <CL_ALV_CONTROL>.
Вариант 1:
Стиль для столбца можно указать в филд-каталоге (LVC_T_FCAT) в полях:
STYLE
STYLE2
STYLE3
STYLE4
Пример:
ls_fcat-style = ALV_STYLE_COLOR_INT_BACKGROUND + ALV_STYLE_ALIGN_CENTER_CENTER.
Вариант 2:
Если необходимо чтобы разные стили были у разных произвольных ячеек, то в стуктуру вашей внутренней таблицы для ALV придется ввести поле типа LVC_T_STYL. В нем будет заполняться таблица стилей для каждой ячейки выбранной строки.
Структура этой таблицы выглядит так:
FIELDNAME TYPE LVC_FNAME,
STYLE TYPE LVC_STYLE,
STYLE2 TYPE LVC_STYLE,
STYLE3 TYPE LVC_STYLE,
STYLE4 TYPE LVC_STYLE,
MAXLEN TYPE INT4.
И собственно заполняется так же как и в филд-каталоге, только для каждой ячейки каждой строки вашей внутренней таблицы для ALV. Важно, таблица стилей должна заполняться так, чтобы в результате получилась таблица отсортированная по FIELDNAME.
Ну и в конце концов необходимо указать имя поля с таблицей стилей в лэйаут ALV (LVC_S_LAYO).
Пример:
tcalend_g_layo-sel_mode = 'A'.
tcalend_g_layo-stylefname = 'CELLTAB'. Подробнее...
Вариант 1:
Стиль для столбца можно указать в филд-каталоге (LVC_T_FCAT) в полях:
STYLE
STYLE2
STYLE3
STYLE4
Пример:
ls_fcat-style = ALV_STYLE_COLOR_INT_BACKGROUND + ALV_STYLE_ALIGN_CENTER_CENTER.
Вариант 2:
Если необходимо чтобы разные стили были у разных произвольных ячеек, то в стуктуру вашей внутренней таблицы для ALV придется ввести поле типа LVC_T_STYL. В нем будет заполняться таблица стилей для каждой ячейки выбранной строки.
Структура этой таблицы выглядит так:
FIELDNAME TYPE LVC_FNAME,
STYLE TYPE LVC_STYLE,
STYLE2 TYPE LVC_STYLE,
STYLE3 TYPE LVC_STYLE,
STYLE4 TYPE LVC_STYLE,
MAXLEN TYPE INT4.
И собственно заполняется так же как и в филд-каталоге, только для каждой ячейки каждой строки вашей внутренней таблицы для ALV. Важно, таблица стилей должна заполняться так, чтобы в результате получилась таблица отсортированная по FIELDNAME.
Ну и в конце концов необходимо указать имя поля с таблицей стилей в лэйаут ALV (LVC_S_LAYO).
Пример:
tcalend_g_layo-sel_mode = 'A'.
tcalend_g_layo-stylefname = 'CELLTAB'. Подробнее...
ABAP: FM для вычисления даты +/- определенное кол-во дней
ФМ – DATE_IN_FUTURE, во входных параметрах дата должна быть в формате “ddmmyyyy”
Пример:
lv_datum+0 = sy-datum+6(2).
lv_datum+2 = sy-datum+4(2).
lv_datum+4 = sy-datum(4).
CALL FUNCTION 'DATE_IN_FUTURE'
EXPORTING
ANZAHL_TAGE = -10
IMPORT_DATUM = lv_datum
IMPORTING
* EXPORT_DATUM_EXT_FORMAT =
EXPORT_DATUM_INT_FORMAT = lv_fdmdt.
А то все время забываю как он называется. Подробнее...
Пример:
lv_datum+0 = sy-datum+6(2).
lv_datum+2 = sy-datum+4(2).
lv_datum+4 = sy-datum(4).
CALL FUNCTION 'DATE_IN_FUTURE'
EXPORTING
ANZAHL_TAGE = -10
IMPORT_DATUM = lv_datum
IMPORTING
* EXPORT_DATUM_EXT_FORMAT =
EXPORT_DATUM_INT_FORMAT = lv_fdmdt.
А то все время забываю как он называется. Подробнее...
Подписаться на:
Сообщения (Atom)