禁用 VA01 中的列

Posted

技术标签:

【中文标题】禁用 VA01 中的列【英文标题】:Disable Column in VA01 【发布时间】:2016-02-25 13:33:37 【问题描述】:

我有一个要求,我需要禁用销售订单行项目中的完整列。字段为 VBAP-ARKTXVBAP-KDMAT

我找到了禁用包含数据的列的方法,但不是整个列。

我使用 USEREXIT_FIELD_MODIFICATION 通过以下代码实现了这一点;

IF sy-TCODE = 'VA02'.
  IF screen-name = 'VBAP-KDMAT' .
      screen-INPUT = 0.
      modify screen.
  ENDIF.
ENDIF.

有没有办法禁用整列?

【问题讨论】:

【参考方案1】:

Adjusting table control 包含项目是最简单也是最推荐的方式。它可以为单个用户或一组用户完成。 否则,尝试在 SHD0 中创建一个screen variant。它可以轻松隐藏任何表格的任何列和屏幕上的任何字段。

【讨论】:

【参考方案2】:

我面临的具体问题是如何禁用两个字段,但让标准映射数据显示在其中。

为了满足这个要求,我使用了以下内容;

包括:MV45AFZZ 用户出口名称:USEREXIT_FIELD_MODIFICATION 增强名称:-您想要的任何名称-

我创建了一个增强功能并编写了以下代码;

"Specify the condition
IF VBAK-VKORG = '1234' AND ( sy-TCODE = 'VA02' OR sy-TCODE = 'VA01' ) AND ( screen-name = 'VBAP-KDMAT' OR screen-name = 'VBAP-ARKTX' ).

        screen-input = 0."disable input
        MODIFY SCREEN.

         DATA: i_tab_mara TYPE TABLE OF MARA WITH HEADER LINE.
         DATA: l_maktx TYPE MAKT-MAKTX.
         DATA: WA_MARA LIKE LINE OF i_tab_mara.

         DATA: i_tab_vbap TYPE TABLE OF VBAP WITH HEADER LINE.
         DATA: wa_vbap LIKE LINE OF i_tab_vbap.

          IF sy-TCODE = 'VA01' .

             SELECT SINGLE * from MARA INTO WA_MARA WHERE MATNR eq VBAP-MATNR.

             SELECT MAKTX FROM MAKT INTO l_maktx WHERE MATNR eq VBAP-MATNR.
             ENDSELECT.

             VBAP-KDMAT = WA_MARA-KDMAT.
             VBAP-ARKTX = l_maktx.

             MODIFY SCREEN.

          ELSEIF sy-TCODE = 'VA02' .

           SELECT SINGLE * FROM VBAP INTO WA_VBAP WHERE VBELN eq VBAK-VBELN AND POSNR eq VBAP-POSNR.

           IF WA_VBAP-ARKTX eq ''." Check if the fileds are empty, otherwise old data is overwritten

             SELECT MAKTX FROM MAKT INTO l_maktx WHERE MATNR eq VBAP-MATNR.
             ENDSELECT.

             VBAP-ARKTX = l_maktx.

             MODIFY SCREEN.

           ENDIF.

           IF WA_VBAP-KDMAT eq ''." Check if the fileds are empty, otherwise old data is overwritten

             SELECT SINGLE * from MARA INTO WA_MARA WHERE MATNR eq VBAP-MATNR.

             VBAP-KDMAT = WA_MARA-KDMAT.

             MODIFY SCREEN.

           ENDIF.
    ENDIF.
ENDIF.

【讨论】:

【参考方案3】:

您可以在 dynpro-designer 中完成一件事。在那里您可以将 sap-standard-dynpro 修改为 dynpro-modification。 不过,这可能会被下一个版本覆盖。这也是你的选择吗?

【讨论】:

以上是关于禁用 VA01 中的列的主要内容,如果未能解决你的问题,请参考以下文章

如何检查numpy矩阵的列中的所有值是不是相同?

像 Qlik 一样计算 pandas 数据框中的列中的唯一值?

在另一列中使用一列中的值

您如何从文件中的列中 grep/awk?

如何从熊猫数据框中的列中删除字符串值

如何在 QT C++ 中从表的列中获取 SQL 中的所有值