메뉴 건너뛰기

SAP 한국 커뮤니티

안녕하세요.

 

ABAP 초보 개발자 입니다.ㅠㅠ

 

간단한거 같은데 어려운 문제에 봉착하여, 하루를 날려먹고 답답한 마음에 문의를 드립니다.

 

문제는 ALV에 소문자를 입력하고나서 ENTER나 Cell을 옮기면 " HANDLE_DATA_CHANGED"를 타는데

 

그 후에 이 입력된 소문자가 대문자로 강제변환이 되어버립니다...

 

여러 글을 찾아보면서 여러가지 방법을 사용해 보았습니다.

 

Field 카탈로그에 필드별로 lowercase = 'X' 넣기... 그리고 LAYOUT부분에 셋팅값들 수정해보기.... Table에 도메인 셋팅 확인..등

 

해보았는데 모두 소용이 없었습니다.ㅠㅠ

 

현재 CBO테이블을 만들어서 단순 데이터 입력/저장 화면을 구현하면서, CBO테이블에 필드 유형을 "CHAR"로 주고 길이를 1000정도 넣어놓은 상태이며,

 

전혀 도메인을 사용하지 않았습니다. (이부분이 의심되기도 합니다...)

 

도무지 왜이러는지 몰라 답답한 마음에 글을 적어보며,

 

혹시나 같은 문제로 어려움을 경험하셨거나 문제점을 아시는분은 답변 부탁드립니다.

 

감사합니다.

 

 

 

 

---------------------------------------------------참조 소스----------------------------------------------------------------

어느 부분인지 몰라 제가 의심되는 부분 캡쳐해봅니다...

 

데[이터 체인지 이벤트

FORM HANDLE_DATA_CHANGED  USING
   P_ER_DATA_CHANGED  TYPE REF TO CL_ALV_CHANGED_DATA_PROTOCOL
   P_E_ONF4           TYPE CHAR01
   P_E_ONF4_BEFORE    TYPE CHAR01
   P_E_ONF4_AFTER     TYPE CHAR01
   P_SENDER           TYPE ANY.

  DATA: LV_ERR(1).

  DATA: LS_MODI     TYPE LVC_S_MODI.

  CLEAR: LV_ERR,
         LS_MODI.

  LOOP AT P_ER_DATA_CHANGED->MT_MOD_CELLS INTO LS_MODI.
    CLEAR: LV_ERR.

    CASE P_SENDER.
      WHEN GV_GRID1.
        READ TABLE GT_LIST INTO GS_LIST INDEX LS_MODI-ROW_ID.
        IF SY-SUBRC <> 0.
          CONTINUE.
        ENDIF.

        CASE LS_MODI-FIELDNAME.
        ENDCASE.

        GS_LIST-MODI_F = 'X'.

      MODIFY GT_LIST FROM GS_LIST INDEX LS_MODI-ROW_ID.
    ENDCASE.

    MODIFY P_ER_DATA_CHANGED->MT_MOD_CELLS FROM LS_MODI.

  ENDLOOP.

  CALL METHOD P_ER_DATA_CHANGED->REFRESH_PROTOCOL.
  CALL METHOD CL_GUI_CFW=>FLUSH.

* ALV 리프래쉬
  PERFORM REFRESH_TABLE_DISP.

ENDFORM.                    " HANDLE_DATA_CHANGED

 

 

 

 

필드카탈로그 셋팅 FROM

 

FORM MODIFY_FIEDCAT1 .

  DATA: LV_TEXT(100).

  CLEAR: LV_TEXT,
         GS_FIELDCAT1.

  LOOP AT GT_FIELDCAT1 INTO GS_FIELDCAT1.
    CLEAR: LV_TEXT,
           GS_FIELDCAT1-KEY,
           GS_FIELDCAT1-FIX_COLUMN.

    if gv_mode = 'C'.

      CASE GS_FIELDCAT1-FIELDNAME.
        WHEN 'SAUP'.
          LV_TEXT                 = TEXT-F02.
          GS_FIELDCAT1-COL_POS    = 20.
          GS_FIELDCAT1-LOWERCASE = C_X.
*          GS_FIELDCAT1-EDIT       = C_X.
*          GS_FIELDCAT1-KEY        = C_X.
*          GS_FIELDCAT1-FIX_COLUMN = C_X.

        WHEN 'WBSNO'.
          LV_TEXT                 = TEXT-F03.
          GS_FIELDCAT1-COL_POS    = 30.
*          GS_FIELDCAT1-EDIT       = C_X.
          GS_FIELDCAT1-LOWERCASE = C_X.

        WHEN 'PROJNM'.
          LV_TEXT                 = TEXT-F04.
          GS_FIELDCAT1-COL_POS    = 40.
*          GS_FIELDCAT1-EDIT       = C_X.
          GS_FIELDCAT1-LOWERCASE = C_X.

        WHEN 'ITEMNM'.              "총미수금
          LV_TEXT                 = TEXT-F05.
          GS_FIELDCAT1-COL_POS    = 50.
*          GS_FIELDCAT1-EDIT       = C_X.
          GS_FIELDCAT1-LOWERCASE = C_X.
*          GS_FIELDCAT1-CFIELDNAME = 'WAERS'.

        WHEN 'SIZE_S'.             "경고미수금
          LV_TEXT                 = TEXT-F06.
          GS_FIELDCAT1-COL_POS    = 60.
*          GS_FIELDCAT1-EDIT       = C_X.
          GS_FIELDCAT1-LOWERCASE = C_X.
*          GS_FIELDCAT1-CFIELDNAME = 'WAERS'.

        WHEN 'BUYER'.             "통화
          LV_TEXT                 = TEXT-F07.
          GS_FIELDCAT1-COL_POS    = 70.
          GS_FIELDCAT1-JUST       = C_C.
*          GS_FIELDCAT1-EDIT       = C_X.
          GS_FIELDCAT1-LOWERCASE = C_X.

        WHEN 'EXDT'.
          LV_TEXT                 = TEXT-F08.
          GS_FIELDCAT1-COL_POS    = 80.
*          GS_FIELDCAT1-EDIT       = C_X.

        WHEN 'ETC'.
          LV_TEXT                 = TEXT-F09.
          GS_FIELDCAT1-COL_POS    = 80.
*          GS_FIELDCAT1-EDIT       = C_X.
          GS_FIELDCAT1-LOWERCASE = C_X.
          GS_FIELDCAT1-JUST     = 'C'.

        WHEN OTHERS.
          GS_FIELDCAT1-NO_OUT = C_X.
          GS_FIELDCAT1-LOWERCASE = C_X.
      ENDCASE.

    else.

      CASE GS_FIELDCAT1-FIELDNAME.
        WHEN 'SAUP'.
          LV_TEXT                 = TEXT-F02.
          GS_FIELDCAT1-COL_POS    = 20.
*          GS_FIELDCAT1-EDIT       = ''.
          GS_FIELDCAT1-LOWERCASE = C_X.
*          GS_FIELDCAT1-KEY        = C_X.
*          GS_FIELDCAT1-FIX_COLUMN = C_X.

        WHEN 'WBSNO'.
          LV_TEXT                 = TEXT-F03.
          GS_FIELDCAT1-COL_POS    = 30.
*          GS_FIELDCAT1-EDIT       = ''.
          GS_FIELDCAT1-LOWERCASE = C_X.

        WHEN 'PROJNM'.
          LV_TEXT                 = TEXT-F04.
          GS_FIELDCAT1-COL_POS    = 40.
*          GS_FIELDCAT1-EDIT       = ''.
          GS_FIELDCAT1-LOWERCASE = C_X.

        WHEN 'ITEMNM'.              "총미수금
          LV_TEXT                 = TEXT-F05.
          GS_FIELDCAT1-COL_POS    = 50.
*          GS_FIELDCAT1-EDIT       = ''.
          GS_FIELDCAT1-LOWERCASE = C_X.
*          GS_FIELDCAT1-CFIELDNAME = 'WAERS'.

        WHEN 'SIZE_S'.             "경고미수금
          LV_TEXT                 = TEXT-F06.
          GS_FIELDCAT1-COL_POS    = 60.
*          GS_FIELDCAT1-EDIT       = ''.
          GS_FIELDCAT1-LOWERCASE = C_X.
*          GS_FIELDCAT1-CFIELDNAME = 'WAERS'.

        WHEN 'BUYER'.             "통화
          LV_TEXT                 = TEXT-F07.
          GS_FIELDCAT1-COL_POS    = 70.
          GS_FIELDCAT1-JUST       = C_C.
*          GS_FIELDCAT1-EDIT       = ''.
          GS_FIELDCAT1-LOWERCASE = C_X.

        WHEN 'EXDT'.
          LV_TEXT                 = TEXT-F08.
          GS_FIELDCAT1-COL_POS    = 80.
*          GS_FIELDCAT1-EDIT       = ''.

        WHEN 'ETC'.
          LV_TEXT                 = TEXT-F09.
          GS_FIELDCAT1-COL_POS    = 80.
*          GS_FIELDCAT1-EDIT       = ''.
          GS_FIELDCAT1-LOWERCASE = C_X.
          GS_FIELDCAT1-JUST     = 'C'.

        WHEN OTHERS.
          GS_FIELDCAT1-NO_OUT = C_X.
          GS_FIELDCAT1-LOWERCASE = C_X.
      ENDCASE.
    endif.

      IF LV_TEXT IS NOT INITIAL.
         GS_FIELDCAT1-SCRTEXT_S
         = GS_FIELDCAT1-SCRTEXT_M
         = GS_FIELDCAT1-SCRTEXT_L
         = GS_FIELDCAT1-COLTEXT
         = GS_FIELDCAT1-REPTEXT = LV_TEXT.
      ENDIF.

      MODIFY GT_FIELDCAT1 FROM GS_FIELDCAT1.

  ENDLOOP.

ENDFORM.                    " MODIFY_FIEDCAT1

 

 

위 필드카탈로그 셋팅하기전 타는 부분

FORM GET_FIELDCAT_MERGE2  TABLES   PT_DATA     TYPE TABLE
                          USING    PT_FIELDCAT TYPE LVC_T_FCAT
                                   P_NAME      TYPE SLIS_TABNAME.

  DATA: LV_NAME    TYPE SLIS_TABNAME.

  DATA: LT_FCAT    TYPE SLIS_T_FIELDCAT_ALV WITH HEADER LINE.

  CLEAR: LV_NAME,
         PT_FIELDCAT[],
         LT_FCAT[].

  LV_NAME = P_NAME.

  CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
    EXPORTING
      I_PROGRAM_NAME               = SY-CPROG
      I_INTERNAL_TABNAME           = LV_NAME
*     I_STRUCTURE_NAME             =
*     I_CLIENT_NEVER_DISPLAY       = 'X'
      I_INCLNAME                   = SY-CPROG
*     I_BYPASSING_BUFFER           =
*     I_BUFFER_ACTIVE              =
    CHANGING
      CT_FIELDCAT                  = LT_FCAT[]
    EXCEPTIONS
      INCONSISTENT_INTERFACE       = 1
      PROGRAM_ERROR                = 2
      OTHERS                       = 3
            .
  IF SY-SUBRC <> 0.
  ENDIF.

  CALL FUNCTION 'LVC_TRANSFER_FROM_SLIS'
    EXPORTING
      IT_FIELDCAT_ALV       = LT_FCAT[]
*     IT_SORT_ALV           =
*     IT_FILTER_ALV         =
*     IS_LAYOUT_ALV         =
    IMPORTING
      ET_FIELDCAT_LVC       = PT_FIELDCAT[]
*     ET_SORT_LVC           =
*     ET_FILTER_LVC         =
*     ES_LAYOUT_LVC         =
    TABLES
      IT_DATA               = PT_DATA
    EXCEPTIONS
      IT_DATA_MISSING       = 1
      OTHERS                = 2
            .
  IF SY-SUBRC <> 0.
  ENDIF.

  CALL FUNCTION 'LVC_FIELDCAT_COMPLETE'
    CHANGING
      CT_FIELDCAT = PT_FIELDCAT.

ENDFORM.                    " GET_FIELDCAT_MERGE2

 

 

ALV가 이미 만들어지고 난뒤 수정하고 다시 ALV를 재구성하는거라 ALV구성시 아래부분을 수행합니다.

 

FORM REFRESH_ALV  USING  P_GRID     TYPE REF TO CL_GUI_ALV_GRID
                         P_FIELDCAT TYPE LVC_T_FCAT
                         P_LAYOCAT  TYPE LVC_S_LAYO.

* 필드카탈로그
  CALL METHOD P_GRID->SET_FRONTEND_FIELDCATALOG
    EXPORTING
      IT_FIELDCATALOG = P_FIELDCAT[].

* 레이아웃
  CALL METHOD P_GRID->SET_FRONTEND_LAYOUT
    EXPORTING
      IS_LAYOUT = P_LAYOCAT.

  GS_SCROLL-ROW = 'X'.
  GS_SCROLL-COL = 'X'.

  CALL METHOD P_GRID->REFRESH_TABLE_DISPLAY
    EXPORTING
      I_SOFT_REFRESH = ' '
      IS_STABLE      = GS_SCROLL.

  CALL METHOD CL_GUI_CFW=>FLUSH.

ENDFORM.                    " REFRESH_ALV

번호 제목 글쓴이 날짜 조회 수
6327 [요청]delete 하는법 알려주세요...조건에 맞는필드를 삭제하려고요... [5] 아밥! 2008.11.06 4683
6326 온라인프로그램에 두개의 컨테이너를 지정후 alv 적용 아시는 분? [1] 노력&성장 2007.08.19 4675
6325 [요청]loop 안에 if문에서 걸렸을때 loop까지 한번에 빠져나오려면?? [5] bizarre 2008.11.10 4673
6324 <b>[완료]</b>[질문]4개이상의 TABLE INNER JOIN 방법 [5] 아싸ㅎ 2008.04.03 4672
6323 [요청]VL31N 화면을 통한 인바운드납품 처리하는 BAPI로 GN_DELIVERY_CREATE 사용하려합니다. [2] 넷가이 2008.10.07 4646
6322 <img src=2.gif>Smartform 을 이용한 PDF 파일 변환시, 한국어/중국어 글씨가 깨져서 나옵니다. ㅠㅠ [4] 쿨쿨 2010.12.21 4634
6321 <img src=2.gif>SET UPDATE TASK LOCAL <- 관해 문의드립니다. [2] 맹꽁이 2009.12.01 4617
6320 <b>[완료]</b>팝업창에서 메시지를 두줄로 쓰는게 가능한가요. [5] 대략나 2008.02.18 4616
6319 <img src=3.gif>매크로 연동 엑셀에서 PDF 전환 후 메일 첨부... [4] 블랙아이즈 2010.06.19 4596
6318 [요청]import, export 구문의 대한 궁금정 [5] copine 2009.03.20 4581
6317 <b>[완료]</b>[re][re] 개인pc에 SAP NetWeaver 2004s 설치방법에 질문입니다. [4] sapjoy 2006.12.27 4578
6316 [요청]EU_SCRP_WN32 : timeout during allocate / CPIC-CALL: 'ThSAPCMRCV' 노름마치 2007.12.14 4569
6315 <img src=2.gif>엑셀 업로드시 [17] sapjoy 2007.03.19 4561
6314 [요청]Batch Job Cancel시 기록이 되는 테이블이 있나요? [5] SAP폐인 2009.02.23 4552
6313 <b>[완료]</b><b>[완료]</b>ALV GRID 초기화 하는 메소드? [1] SARA 2007.03.29 4548
6312 <img src=3.gif>문자열 자릿수 계산 질문입니다!! [5] ASDF 2010.11.09 4540
6311 <b>[완료]</b>LOCK OBJECT 에서 잠긴(ENQUEUE) 데이터를 프로그램에서 알 수 있는지 궁금합니다. [8] 하이원 2008.02.20 4523
6310 <b>[완료]</b>자동채번에 관해 문의드립니다. [7] 풍뎅이 2008.06.03 4519
6309 <img src=3.gif>RFC를 사용하여 델파이와 연동시 한글깨짐 현상이요 [4] 지니 2010.09.09 4516
6308 <img src=2.gif border=0>F4IF_INT_TABLE_VALUE_REQUEST 질문입니다. [2] 뫄* 2009.07.15 4508