loop of 和loop at 区别
在 ABAP 中,“LOOP OF” 和 “LOOP AT” 是用于循环遍历内表或内部表元素的两种不同的关键字。
a. “LOOP OF” 语句:
“LOOP OF” 是 ABAP 7.40 以后引入的语法,用于遍历内表的元素。
它的基本语法为:LOOP OF <internal_table> [WHERE ] [GROUP BY ] [USING <group_key>] [HAVING <group_condition>].
可以在循环体内使用 “LOOP AT” 或其他处理语句来操作当前遍历的元素。
b. “LOOP AT” 语句:
“LOOP AT” 是 ABAP 中经典的用于遍历内表的循环语句。
它的基本语法为:LOOP AT <internal_table> INTO <work_area> [WHERE ].
在循环体内,可以使用 <work_area> 中的字段来操作当前遍历的元素。
这两种关键字的区别在于语法和使用方式上的不同。“LOOP OF” 主要用于简化代码和提高可读性,它支持更多的条件筛选和分组功能。而 “LOOP AT” 则是较早引入的循环语法,也是传统和常用的循环方式之一。
以下是使用 “LOOP OF” 和 “LOOP AT” 的示例:
使用 “LOOP OF”:
DATA: lt_table TYPE TABLE OF string,
lv_element TYPE string.
APPEND 'Element 1' TO lt_table.
APPEND 'Element 2' TO lt_table.
APPEND 'Element 3' TO lt_table.
LOOP OF lt_table INTO lv_element.
WRITE: / lv_element.
ENDLOOP.
使用 “LOOP AT”:
DATA: lt_table TYPE TABLE OF string,
ls_element TYPE string.
APPEND 'Element 1' TO lt_table.
APPEND 'Element 2' TO lt_table.
APPEND 'Element 3' TO lt_table.
LOOP AT lt_table INTO ls_element.
WRITE: / ls_element.
ENDLOOP.
两者的执行结果相同,都会遍历内表 lt_table 中的每个元素,并将元素的值输出到屏幕上。
根据个人喜好和代码习惯,您可以选择使用 “LOOP OF” 或 “LOOP AT”,或者根据业务需求选择更适合的关键字来编写循环逻辑。