Sapforum.Biz

Инструменты => ABAP - Инструментальные средства => SE38 - ABAP Редактор => Тема розпочата: Паганель від Березень 13, 2009, 05:08:00 ПП

Назва: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 13, 2009, 05:08:00 ПП
Хотелось бы вызвать ту же mb5b и после того как она отработает, считать данные с ее таблички в которую она сохраняет.

по аналогии с ASSIGN ('(SAPMM07M)xmseg[]') TO <fs_mseg>.

для RM07MLBD_FORM_02
G_T_BELEGE1

не подскажете возможно ли это, и как это сделать?
Назва: Как подломить стандартный отчет и получить его выборки (таблички)
Відправлено: Паганель від Березень 13, 2009, 05:10:16 ПП
Откуда начать копать? Это типа продолжение темы http://sapforum.biz/index.php/topic,543.new.html
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 13, 2009, 05:27:52 ПП
В общем случае задача не имеет решения, так как вызов ASSIGN ('(SAPMM07M)xmseg[]') TO <fs_mseg> работает в контексте транзакции из экзита и к этому моменту данные есть в памяти. В твоем же случае ситуация такая что программа уже отработала и локальных и прочих данных уже нет. Для MB51 например при правильном вызове эта транзакция сохраняет данные через IMPORT TO MEMORY поэтому ее результат можно считать. Можно ли для MB5B такое же... ну при беглом просмотре кода, ничего похожего не найдено.
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 13, 2009, 05:39:35 ПП
Жаль конечно  :(
Тогда переходим к обсуждению темы про подлом стандартных транзакций ....тока где-то нету ее
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 13, 2009, 05:40:41 ПП
Цитата: Паганель від Березень 13, 2009, 05:39:35 ПП
Жаль конечно  :(
Тогда переходим к обсуждению темы про подлом стандартных транзакций ....тока где-то нету ее
А ее перенесли сюда, ну что же тогда тут и продолжаем
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 13, 2009, 05:48:16 ПП
Цитата: Паганель від Березень 13, 2009, 05:39:35 ПП
Жаль конечно  :(
Тогда переходим к обсуждению темы про подлом стандартных транзакций ....тока где-то нету ее
Называется SE38 а там копируешь стандартную программу в свою и делаешь с ней чего хочешь, вот тебе и все подлом...
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 13, 2009, 05:56:40 ПП
Цитата: Uukrul від Березень 13, 2009, 05:48:16 ПП
Называется SE38 а там копируешь стандартную программу в свою и делаешь с ней чего хочешь, вот тебе и все подлом...

Это то же решение, правда один недостаток: если будут обновления (изменения логики выбора, исправления ошибок), и они затронут mb5b, твою прогу они не затронут.
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Dmitriy від Березень 13, 2009, 05:57:56 ПП
Есть еще такой момент, разобраться в отчете и уже написать в своем все нужные выборки, т.е. безо всяких вызовов делаешь свой собственный отчет "с нуля".
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Dmitriy від Березень 13, 2009, 05:59:01 ПП
Цитата: Паганель від Березень 13, 2009, 05:56:40 ПП
Это то же решение, правда один недостаток: если будут обновления (изменения логики выбора, исправления ошибок), и они затронут mb5b, твою прогу они не затронут.
Поэтому нужно разбираться в mb5b.
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 13, 2009, 06:01:52 ПП
Цитата: Dmitriy від Березень 13, 2009, 05:59:01 ПП
Поэтому нужно разбираться в mb5b.

Не понял ..... что ты имел ввиду?
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Dmitriy від Березень 13, 2009, 06:06:22 ПП
Тебе же в своем отчете нужны данные mb5b? Вот если разобраться в коде и написать в своем отчете его, то и получишь нужные тебе результаты. Можно готовое вставлять, можно п/п использовать, даже не копируя. Варианты, в общем, есть!
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 14, 2009, 11:01:59 ДП
Цитата: Паганель від Березень 13, 2009, 05:56:40 ПП
Это то же решение, правда один недостаток: если будут обновления (изменения логики выбора, исправления ошибок), и они затронут mb5b, твою прогу они не затронут.
Если ты сломаешь любую стандартную транзакцию, то обновления ей уже не грозят...
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 14, 2009, 12:21:16 ПП
Цитата: Uukrul від Березень 14, 2009, 11:01:59 ДП
Если ты сломаешь любую стандартную транзакцию, то обновления ей уже не грозят...

Я имел ввиду расширение, т.е. UserExit или что-то подобное ....
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Dmitriy від Березень 14, 2009, 01:14:01 ПП
Цитата: Паганель від Березень 14, 2009, 12:21:16 ПП
Я имел ввиду расширение, т.е. UserExit или что-то подобное ....
Для подобного вида транзакций это можно сделать только через неявную точку расширения, где воткнуть EXPORT, а потом в своем отчете IMPORT.
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 14, 2009, 04:33:30 ПП
Ну где-то так как написал тут: http://sapforum.biz/index.php/topic,546.0.html
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 25, 2009, 01:21:30 ПП
Цитата: Uukrul від Березень 13, 2009, 05:27:52 ПП
Для MB51 например при правильном вызове эта транзакция сохраняет данные через IMPORT TO MEMORY поэтому ее результат можно считать. Можно ли для MB5B такое же... ну при беглом просмотре кода, ничего похожего не найдено.

То есть речь идет об SUBMIT *** AND RETURN EXPORTING LIST TO MEMORY?

Цитата: Uukrul від Березень 13, 2009, 05:27:52 ПП
ну при беглом просмотре кода, ничего похожего не найдено.
А по каким критериям определяется можно ли использовать EXPORTING LIST TO MEMORY ?

Кстати вот нашел (для другой транз. правда) http://www.sapnet.ru/viewtopic.php?t=1893&highlight=syucomm+list
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 25, 2009, 01:33:55 ПП
Ну так экспорт через память можно только тогда, когда формирование отчета выполняется через операторы WRITE, т.е. абап списком. Если, же отчет ALV, то и экспортировать нечего. В твоем случае MB5B таки можно экспортировать в память.
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 25, 2009, 01:37:57 ПП
Ураааааааааа .........  :)
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 25, 2009, 05:52:09 ПП
Следующий вопрос: может кто знает как потом значения вытянуть после того как експортировали в память?
Нашел только ф-ию LIST_FROM_MEMORY но .....

Делаю так:

FORM call_mb5b
      USING
             zwerks LIKE  z_mkpf_mseg-werks
             zmatnr LIKE mara-matnr
             bdate_rest TYPE sy-datum.
           "  edate_rest TYPE sy-datum.
*      CHANGING
*        brest_menge TYPE z_mkpf_mseg-menge " остаток на начало
*        brest_dmbtr TYPE z_mkpf_mseg-dmbtr
*        erest_menge TYPE z_mkpf_mseg-menge " остаток на конец
*        erest_dmbtr TYPE z_mkpf_mseg-dmbtr.

  SUBMIT RM07MLBD
  WITH MATNR = zmatnr
  WITH WERKS = zwerks
  WITH BUDAT = bdate_rest
  EXPORTING LIST TO MEMORY AND RETURN.

  DATA: ABAPLIST LIKE ABAPLIST OCCURS 0.
  CALL FUNCTION 'LIST_FROM_MEMORY'
  TABLES
    LISTOBJECT = ABAPLIST
  EXCEPTIONS
    NOT_FOUND = 1
    OTHERS = 2.

*if sy-batch = space.
  CALL FUNCTION 'DISPLAY_LIST'
  EXPORTING
    FULLSCREEN = 'X'
  IMPORTING
    USER_COMMAND = SY-UCOMM
  TABLES
    LISTOBJECT = ABAPLIST
  EXCEPTIONS
    EMPTY_LIST = 1
    OTHERS = 2.
ENDFORM.

Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 25, 2009, 06:00:07 ПП
Цитата: Паганель від Березень 25, 2009, 05:52:09 ПП
Нашел только ф-ию LIST_FROM_MEMORY но .....
Что но?
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 25, 2009, 09:02:19 ПП
Что-что  :), таким образом как в примере выше, я могу просто вывести ALV List такой же как и в mb5b
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 25, 2009, 09:34:08 ПП
А дальше типа так, получаешь вменяемый текст и из него пытаешься выцепить нужные тебе данные...

DATA: BEGIN OF lt_list OCCURS 1,
  str(1000) TYPE c,
END OF lt_list.

CALL FUNCTION 'LIST_TO_ASCI'
* EXPORTING
*   LIST_INDEX               = -1
*   WITH_LINE_BREAK          = ' '
* IMPORTING
*   LIST_STRING_ASCII        =
*   LIST_DYN_ASCII           =
TABLES
   listasci                 = lt_list
   listobject               = abaplist
EXCEPTIONS
   empty_list               = 1
   list_index_invalid       = 2
   OTHERS                   = 3.
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 25, 2009, 09:37:40 ПП
Парсинг строк отчета думаю сам напишешь? Если задавать как у тебя завод, материал... то там вообще будет все просто, с вытаскиванием запаса.
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 25, 2009, 11:39:23 ПП
Цитата: Uukrul від Березень 25, 2009, 09:37:40 ПП
Парсинг строк отчета думаю сам напишешь? Если задавать как у тебя завод, материал... то там вообще будет все просто, с вытаскиванием запаса.

Сложновато будет, нет какого-то у тебя примерчика, да и не понятно как к строке достучатся, там как я понял какая то табличка непонятной структуры
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 26, 2009, 12:00:03 ДП
Табличка очень понятной структуры... что видно из аттачмента. Получить данные можно где-то так... при условии что задаешь поиск по материал/завод, то все будет работать.

DATA: l_start LIKE mseg-menge,
      l_plus LIKE mseg-menge,
      l_minus  LIKE mseg-menge,
      l_end LIKE mseg-menge,
      l_index LIKE sy-tabix.
LOOP AT lt_list.
  IF lt_list-str(8) = 'Запас на'.
    l_start = lt_list-str+20(25).

    l_index = sy-tabix + 1.
    READ TABLE lt_list INDEX l_index.
    l_plus = lt_list-str+20(25).

    l_index = sy-tabix + 1.
    READ TABLE lt_list INDEX l_index.
    l_minus = lt_list-str+20(25).

    l_index = sy-tabix + 1.
    READ TABLE lt_list INDEX l_index.
    l_end = lt_list-str+20(25).

    EXIT.
  ENDIF.
ENDLOOP.

WRITE: / l_start,
       / l_plus,
       / l_minus,
       / l_end.
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 26, 2009, 12:02:13 ДП
Цитата: Uukrul від Березень 25, 2009, 09:34:08 ПП
А дальше типа так, получаешь вменяемый текст и из него пытаешься выцепить нужные тебе данные...

DATA: BEGIN OF lt_list OCCURS 1,
  str(1000) TYPE c,
END OF lt_list.

CALL FUNCTION 'LIST_TO_ASCI'
* EXPORTING
*   LIST_INDEX               = -1
*   WITH_LINE_BREAK          = ' '
* IMPORTING
*   LIST_STRING_ASCII        =
*   LIST_DYN_ASCII           =
TABLES
   listasci                 = lt_list
   listobject               = abaplist
EXCEPTIONS
   empty_list               = 1
   list_index_invalid       = 2
   OTHERS                   = 3.


Ссори это-т пост не заметил
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Uukrul від Березень 26, 2009, 12:03:23 ДП
Цитата: Паганель від Березень 26, 2009, 12:02:13 ДП
Ссори это-т пост не заметил
Да я уже дальше тебе нарисовал программку  ;)
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 26, 2009, 12:04:50 ДП
Спасибо большое, теперь разберусь, после того как разжевали   ;-)

Шо-то в последнее время АБАП туго идет, почти все время абаплю, функционала почти нет (не дают)
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Березень 26, 2009, 12:10:31 ДП
Да все понятно, разжевал, тут и разбираться  не надо, еще раз спасибо
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Квітень 14, 2009, 10:43:03 ДП
Типа добавлю:
http://abapinsap.ru/?page_id=1062 (http://abapinsap.ru/?page_id=1062)
http://sapforum.biz/index.php?topic=584.0 (http://sapforum.biz/index.php?topic=584.0)
Назва: Re: Вызов транзакции (проги) со своей и последующий забор данных
Відправлено: Паганель від Квітень 30, 2009, 11:24:15 ДП
Типа в копилку знаний.
Еще, люди тоже заморачивались (пока не читал, вечерком гляну)
http://abaplog.wordpress.com/2007/03/01/reading-other-programs-data-using-field-symbols-in-abap/