COBOL - Traitement de table
Les tableaux en COBOL sont appelés tableaux. Un tableau est une structure de données linéaire et est une collection d'éléments de données individuels du même type. Les éléments de données d'une table sont triés en interne.
Déclaration de table
Le tableau est déclaré dans Data Division. Occursclause est utilisée pour définir une table. La clause Occurs indique la répétition de la définition du nom de données. Il ne peut être utilisé qu'avec des numéros de niveau allant de 02 à 49. Ne pas utiliser la clause survient avec Redefines. La description du tableau unidimensionnel et bidimensionnel est la suivante -
Table unidimensionnelle
Dans un tableau unidimensionnel, occursLa clause n'est utilisée qu'une seule fois dans la déclaration. WSTABLE est l'élément de groupe qui contient la table. WS-B nomme les éléments de table qui se produisent 10 fois.
Syntax
Voici la syntaxe pour définir une table unidimensionnelle -
01 WS-TABLE.
05 WS-A PIC A(10) OCCURS 10 TIMES.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A PIC A(10) VALUE 'TUTORIALS' OCCURS 5 TIMES.
PROCEDURE DIVISION.
DISPLAY "ONE-D TABLE : "WS-TABLE.
STOP RUN.
JCL pour exécuter le programme COBOL ci-dessus -
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -
ONE-D TABLE : TUTORIALS TUTORIALS TUTORIALS TUTORIALS TUTORIALS
Table bidimensionnelle
Une table bidimensionnelle est créée avec les deux éléments de données de longueur variable. Pour référence, parcourez la syntaxe, puis essayez d'analyser le tableau. Le premier tableau (WS-A) peut apparaître de 1 à 10 fois et le tableau interne (WS-C) peut apparaître de 1 à 5 fois. Pour chaque entrée de WS-A, il y aura 5 entrées correspondantes de WS-C.
Syntax
Voici la syntaxe pour définir une table à deux dimensions -
01 WS-TABLE.
05 WS-A OCCURS 10 TIMES.
10 WS-B PIC A(10).
10 WS-C OCCURS 5 TIMES.
15 WS-D PIC X(6).
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A OCCURS 2 TIMES.
10 WS-B PIC A(10) VALUE ' TUTORIALS'.
10 WS-C OCCURS 2 TIMES.
15 WS-D PIC X(6) VALUE ' POINT'.
PROCEDURE DIVISION.
DISPLAY "TWO-D TABLE : "WS-TABLE.
STOP RUN.
JCL pour exécuter le programme COBOL ci-dessus -
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -
TWO-D TABLE : TUTORIALS POINT POINT TUTORIALS POINT POINT
Indice
Les éléments individuels du tableau sont accessibles à l'aide de l'indice. Les valeurs de l'indice peuvent aller de 1 au nombre de fois où la table apparaît. Un indice peut être n'importe quel nombre positif. Il ne nécessite aucune déclaration dans la division des données. Il est automatiquement créé avec la clause survient.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A OCCURS 3 TIMES.
10 WS-B PIC A(2).
10 WS-C OCCURS 2 TIMES.
15 WS-D PIC X(3).
PROCEDURE DIVISION.
MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
DISPLAY 'WS-TABLE : ' WS-TABLE.
DISPLAY 'WS-A(1) : ' WS-A(1).
DISPLAY 'WS-C(1,1) : ' WS-C(1,1).
DISPLAY 'WS-C(1,2) : ' WS-C(1,2).
DISPLAY 'WS-A(2) : ' WS-A(2).
DISPLAY 'WS-C(2,1) : ' WS-C(2,1).
DISPLAY 'WS-C(2,2) : ' WS-C(2,2).
DISPLAY 'WS-A(3) : ' WS-A(3).
DISPLAY 'WS-C(3,1) : ' WS-C(3,1).
DISPLAY 'WS-C(3,2) : ' WS-C(3,2).
STOP RUN.
JCL pour exécuter le programme COBOL ci-dessus -
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -
WS-TABLE : 12ABCDEF34GHIJKL56MNOPQR
WS-A(1) : 12ABCDEF
WS-C(1,1) : ABC
WS-C(1,2) : DEF
WS-A(2) : 34GHIJKL
WS-C(2,1) : GHI
WS-C(2,2) : JKL
WS-A(3) : 56MNOPQR
WS-C(3,1) : MNO
WS-C(3,2) : PQR
Indice
Les éléments de table sont également accessibles à l'aide de l'index. Un index est un déplacement d'élément depuis le début de la table. Un index est déclaré avec la clause Occurs à l'aide de la clause INDEXED BY. La valeur de l'index peut être modifiée à l'aide de l'instruction SET et de l'option PERFORM Varying.
Syntax
Voici la syntaxe pour définir l'index dans une table -
01 WS-TABLE.
05 WS-A PIC A(10) OCCURS 10 TIMES INDEXED BY I.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A OCCURS 3 TIMES INDEXED BY I.
10 WS-B PIC A(2).
10 WS-C OCCURS 2 TIMES INDEXED BY J.
15 WS-D PIC X(3).
PROCEDURE DIVISION.
MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
PERFORM A-PARA VARYING I FROM 1 BY 1 UNTIL I >3
STOP RUN.
A-PARA.
PERFORM C-PARA VARYING J FROM 1 BY 1 UNTIL J>2.
C-PARA.
DISPLAY WS-C(I,J).
JCL pour exécuter le programme COBOL ci-dessus -
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -
ABC
DEF
GHI
JKL
MNO
PQR
Définir la déclaration
L'instruction Set est utilisée pour modifier la valeur d'index. Le verbe Set est utilisé pour initialiser, incrémenter ou décrémenter la valeur d'index. Il est utilisé avec Rechercher et Rechercher tout pour localiser les éléments dans le tableau.
Syntax
Voici la syntaxe pour utiliser une instruction Set -
SET I J TO positive-number
SET I TO J
SET I TO 5
SET I J UP BY 1
SET J DOWN BY 5
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A OCCURS 3 TIMES INDEXED BY I.
10 WS-B PIC A(2).
10 WS-C OCCURS 2 TIMES INDEXED BY J.
15 WS-D PIC X(3).
PROCEDURE DIVISION.
MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
SET I J TO 1.
DISPLAY WS-C(I,J).
SET I J UP BY 1.
DISPLAY WS-C(I,J).
STOP RUN.
JCL pour exécuter le programme COBOL ci-dessus.
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -
ABC
JKL
Chercher
La recherche est une méthode de recherche linéaire utilisée pour rechercher des éléments à l'intérieur du tableau. Il peut être effectué sur une table triée ou non triée. Il n'est utilisé que pour les tables déclarées par la phrase d'index. Il commence par la valeur initiale de l'index. Si l'élément recherché n'est pas trouvé, l'index est automatiquement incrémenté de 1 et il continue jusqu'à la fin de la table.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-A PIC X(1) OCCURS 18 TIMES INDEXED BY I.
01 WS-SRCH PIC A(1) VALUE 'M'.
PROCEDURE DIVISION.
MOVE 'ABCDEFGHIJKLMNOPQR' TO WS-TABLE.
SET I TO 1.
SEARCH WS-A
AT END DISPLAY 'M NOT FOUND IN TABLE'
WHEN WS-A(I) = WS-SRCH
DISPLAY 'LETTER M FOUND IN TABLE'
END-SEARCH.
STOP RUN.
JCL pour exécuter le programme COBOL ci-dessus.
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -
LETTER M FOUND IN TABLE
Rechercher tout
Search All est une méthode de recherche binaire utilisée pour rechercher des éléments à l'intérieur de la table. La table doit être triée pour l'option Rechercher tout. L'index ne nécessite pas d'initialisation. Dans la recherche binaire, le tableau est divisé en deux moitiés et détermine dans quelle moitié l'élément recherché est présent. Ce processus se répète jusqu'à ce que l'élément soit trouvé ou que la fin soit atteinte.
Example
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-TABLE.
05 WS-RECORD OCCURS 10 TIMES ASCENDING KEY IS WS-NUM INDEXED BY I.
10 WS-NUM PIC 9(2).
10 WS-NAME PIC A(3).
PROCEDURE DIVISION.
MOVE '12ABC56DEF34GHI78JKL93MNO11PQR' TO WS-TABLE.
SEARCH ALL WS-RECORD
AT END DISPLAY 'RECORD NOT FOUND'
WHEN WS-NUM(I) = 93
DISPLAY 'RECORD FOUND '
DISPLAY WS-NUM(I)
DISPLAY WS-NAME(I)
END-SEARCH.
JCL pour exécuter le programme COBOL ci-dessus -
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -
RECORD FOUND
93
MNO