cobol基本动词

2023-11-23 01:45
文章标签 基本 动词 cobol

本文主要是介绍cobol基本动词,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

cobol基本动词

基本动词用于过程部中的数据处理。每个语句总是以cobol动词开头。

input(输入)/output(输出)

输入输出动词用于从用户获取数据。并显示cobol程序的输出。

accept

用于从操作系统或者用户获取数据,例如日期、时间等。如果程序从用户获取数据,需要通过jcl传递,从操作系统获取数据from选项如下:

accept yourname.
accept currdate from system-date.

display

用于显示cobol程序的输出。

例:

display yourname.
display '66666'.

initialize(初始化)

用来初始化组或基本项。数据名为rename的子句不能被初始化。
数字数据项由zeroes代替。
字母数据项或字母数字由spaces代替。
如果包含replacing语句,则数据项可被初始化为给定替换的值。

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.DATA DIVISION.WORKING-STORAGE SECTION.01 WS-NAME PIC A(30) VALUE 'ABCDEF'.01 WS-ID PIC 9(5).01 WS-ADDRESS. 05 WS-HOUSE-NUMBER PIC 9(3).05 WS-COUNTRY PIC X(15).05 WS-PINCODE PIC 9(6) VALUE 123456.PROCEDURE DIVISION.A000-FIRST-PARA.INITIALIZE WS-NAME, WS-ADDRESS.INITIALIZE WS-ID REPLACING NUMERIC DATA BY 12345.DISPLAY "My name is   : "WS-NAME.DISPLAY "My ID is     : "WS-ID.DISPLAY "Address      : "WS-ADDRESS.DISPLAY "House Number : "WS-HOUSE-NUMBER.DISPLAY "Country      : "WS-COUNTRY.DISPLAY "Pincode      : "WS-PINCODE.STOP RUN.

move(移动)

移动动词是用来将数据从源数据复制到目标数据的。
它可以用于基本和组数据项。
对于组数据项,使用MOVE CORRESPONDING/CORR。
在尝试其它选项的时候,MOVE CORR不工作;但是在大型机服务器上工作。
对于从字符串移动数据,则使用MOVE(x:l),其中x是起始位置,l是长度。
如果目标数据项PIC子句少于源数据项PIC子句,则数据将被截断。
如果目标数据项PIC子句多于源数据项PIC子句,则将添加额外的ZEROS或SAPCES字节。

例:

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.DATA DIVISION.WORKING-STORAGE SECTION.01 WS-NUM1 PIC 9(9).01 WS-NUM2 PIC 9(9).01 WS-NUM3 PIC 9(5).01 WS-NUM4 PIC 9(6).01 WS-ADDRESS. 05 WS-HOUSE-NUMBER PIC 9(3).05 WS-COUNTRY PIC X(5).05 WS-PINCODE PIC 9(6).01 WS-ADDRESS1. 05 WS-HOUSE-NUMBER1 PIC 9(3).05 WS-COUNTRY1 PIC X(5).05 WS-PINCODE1 PIC 9(6).PROCEDURE DIVISION.A000-FIRST-PARA.MOVE 123456789 TO WS-NUM1.MOVE WS-NUM1 TO WS-NUM2 WS-NUM3.MOVE WS-NUM1(3:6) TO WS-NUM4.MOVE 123 TO WS-HOUSE-NUMBER.MOVE 'INDIA' TO WS-COUNTRY.MOVE 112233 TO WS-PINCODE.MOVE WS-ADDRESS TO WS-ADDRESS1.DISPLAY "WS-NUM1     : " WS-NUM1DISPLAY "WS-NUM2     : " WS-NUM2DISPLAY "WS-NUM3     : " WS-NUM3DISPLAY "WS-NUM4     : " WS-NUM4DISPLAY "WS-ADDRESS  : " WS-ADDRESSDISPLAY "WS-ADDRESS1 : " WS-ADDRESS1STOP RUN.

合法移动

字母字母数字数字
字母可能可能不可能
字母数字可能可能可能
数字不可能可能可能

add(加法)

加法动词用于两个或多个数字相加,并将结果存储在目标运算对象中。

语法
以下为两个或多个数字相加的语法:

ADD A B TO C DADD A B C TO D GIVING EADD CORR WS-GROUP1 TO WS-GROUP2

在语法句1中,A,B,C相加,结果存储在C(C=A+B+C)。A,B,D相加,结果存储在D(D=A+B+D)。
在语法句2中,A,B,C,D相加,结果存储在E(E=A+B+C+D)。
在语法句3中,WS-GROUP1和WS-GROUP2中的子组项相加,结果存储在WS-GROUP2中。

例:

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.DATA DIVISION.WORKING-STORAGE SECTION.01 WS-NUM1 PIC 9(9) VALUE 10 .01 WS-NUM2 PIC 9(9) VALUE 10.01 WS-NUM3 PIC 9(9) VALUE 10.01 WS-NUM4 PIC 9(9) VALUE 10.01 WS-NUMA PIC 9(9) VALUE 10.01 WS-NUMB PIC 9(9) VALUE 10.01 WS-NUMC PIC 9(9) VALUE 10.01 WS-NUMD PIC 9(9) VALUE 10.01 WS-NUME PIC 9(9) VALUE 10.PROCEDURE DIVISION.ADD WS-NUM1 WS-NUM2 TO WS-NUM3 WS-NUM4.ADD WS-NUMA WS-NUMB WS-NUMC TO WS-NUMD GIVING WS-NUME.DISPLAY "WS-NUM1     : " WS-NUM1DISPLAY "WS-NUM2     : " WS-NUM2DISPLAY "WS-NUM3     : " WS-NUM3DISPLAY "WS-NUM4     : " WS-NUM4DISPLAY "WS-NUMA     : " WS-NUMADISPLAY "WS-NUMB     : " WS-NUMBDISPLAY "WS-NUMC     : " WS-NUMCDISPLAY "WS-NUMD     : " WS-NUMDDISPLAY "WS-NUME     : " WS-NUMESTOP RUN.

subtract(减法)

用于减法运算

语法

SUBTRACT A B FROM C DSUBTRACT A B C FROM D GIVING ESUBTRACT CORR WS-GROUP1 TO WS-GROUP2

在语法句1中,A和B相加并从C中减去,结果存储在C(C=C-(A+B))。A和B相加并从D中减去,结果存储在D(D=D-(A+B))。
在语法句2中,A,B,C相加并从D中减去,结果存储在E(E=D-(A+B+C))。
在语法句3中,WS-GROUP1和WS-GROUP2中的子组项相减,结果存储在WS-GROUP2中。

例:

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.DATA DIVISION.WORKING-STORAGE SECTION.01 WS-NUM1 PIC 9(9) VALUE 10 .01 WS-NUM2 PIC 9(9) VALUE 10.01 WS-NUM3 PIC 9(9) VALUE 100.01 WS-NUM4 PIC 9(9) VALUE 100.01 WS-NUMA PIC 9(9) VALUE 10.01 WS-NUMB PIC 9(9) VALUE 10.01 WS-NUMC PIC 9(9) VALUE 10.01 WS-NUMD PIC 9(9) VALUE 100.01 WS-NUME PIC 9(9) VALUE 10.PROCEDURE DIVISION.SUBTRACT WS-NUM1 WS-NUM2 FROM WS-NUM3 WS-NUM4.SUBTRACT WS-NUMA WS-NUMB WS-NUMC FROM WS-NUMD GIVING WS-NUME.DISPLAY "WS-NUM1     : " WS-NUM1DISPLAY "WS-NUM2     : " WS-NUM2DISPLAY "WS-NUM3     : " WS-NUM3DISPLAY "WS-NUM4     : " WS-NUM4DISPLAY "WS-NUMA     : " WS-NUMADISPLAY "WS-NUMB     : " WS-NUMBDISPLAY "WS-NUMC     : " WS-NUMCDISPLAY "WS-NUMD     : " WS-NUMDDISPLAY "WS-NUME     : " WS-NUMESTOP RUN.

multiply(乘法)

用于乘法运算

语法

MULTIPLY A BY B CMULTIPLY A BY B GIVING E

在语法句1中,A和B相乘,结果存储在B(B=AB)。A和C相乘,结果存储在C(C=AC)。
在语法句2中,A和B相乘,结果存储在E(E=A*B)。

例:

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.DATA DIVISION.WORKING-STORAGE SECTION.01 WS-NUM1 PIC 9(9) VALUE 10 .01 WS-NUM2 PIC 9(9) VALUE 10.01 WS-NUM3 PIC 9(9) VALUE 10.01 WS-NUMA PIC 9(9) VALUE 10.01 WS-NUMB PIC 9(9) VALUE 10.01 WS-NUMC PIC 9(9) VALUE 10.PROCEDURE DIVISION.MULTIPLY WS-NUM1 BY WS-NUM2 WS-NUM3.MULTIPLY WS-NUMA BY WS-NUMB GIVING WS-NUMC.DISPLAY "WS-NUM1     : " WS-NUM1DISPLAY "WS-NUM2     : " WS-NUM2DISPLAY "WS-NUM3     : " WS-NUM3DISPLAY "WS-NUMA     : " WS-NUMADISPLAY "WS-NUMB     : " WS-NUMBDISPLAY "WS-NUMC     : " WS-NUMCSTOP RUN.

divide(除法)

用于除法运算

语法

DIVIDE A INTO BDIVIDE A BY B GIVING C REMAINDER R

在语法句1中,B除以A,结果存储在B(B=B/A)。
在语法句2中,A除以B,结果存储在C(C=A/B),余数存储在R。

例:

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.DATA DIVISION.WORKING-STORAGE SECTION.01 WS-NUM1 PIC 9(9) VALUE 5.01 WS-NUM2 PIC 9(9) VALUE 250.01 WS-NUMA PIC 9(9) VALUE 100.01 WS-NUMB PIC 9(9) VALUE 15.01 WS-NUMC PIC 9(9).01 WS-REM PIC 9(9). PROCEDURE DIVISION.DIVIDE WS-NUM1 INTO WS-NUM2.DIVIDE WS-NUMA BY WS-NUMB GIVING WS-NUMC REMAINDER WS-REM.DISPLAY "WS-NUM1     : " WS-NUM1DISPLAY "WS-NUM2     : " WS-NUM2DISPLAY "WS-NUMA     : " WS-NUMADISPLAY "WS-NUMB     : " WS-NUMBDISPLAY "WS-NUMC     : " WS-NUMCDISPLAY "WS-REM      : " WS-REMSTOP RUN.

compute(计算)

用于在cobol中写入算术表达式,替代加减乘除。

例:

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.DATA DIVISION.WORKING-STORAGE SECTION.01 WS-NUM1 PIC 9(9) VALUE 10 .01 WS-NUM2 PIC 9(9) VALUE 10.01 WS-NUM3 PIC 9(9) VALUE 10.01 WS-NUMA PIC 9(9) VALUE 50.01 WS-NUMB PIC 9(9) VALUE 10.01 WS-NUMC PIC 9(9).PROCEDURE DIVISION.COMPUTE WS-NUMC= (WS-NUM1 * WS-NUM2) - (WS-NUMA / WS-NUMB) + WS-NUM3.DISPLAY "WS-NUM1     : " WS-NUM1DISPLAY "WS-NUM2     : " WS-NUM2DISPLAY "WS-NUM3     : " WS-NUM3DISPLAY "WS-NUMA     : " WS-NUMADISPLAY "WS-NUMB     : " WS-NUMBDISPLAY "WS-NUMC     : " WS-NUMCSTOP RUN.

注:本系列文章参考下面网站
参考地址

这篇关于cobol基本动词的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/414439

相关文章

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

DNS查询的利器! linux的dig命令基本用法详解

《DNS查询的利器!linux的dig命令基本用法详解》dig命令可以查询各种类型DNS记录信息,下面我们将通过实际示例和dig命令常用参数来详细说明如何使用dig实用程序... dig(Domain Information Groper)是一款功能强大的 linux 命令行实用程序,通过查询名称服务器并输

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁