OpenVMS - 如果TEXT像x那样删除行

时间:2014-03-12 17:17:48

标签: openvms dcl

我有一个批处理脚本,它将包含路径和版本号的所有文件写入物理设备的TMP文件。然后,此批处理脚本将写入任何演示文件版本号大于提供的变量的行。

DIRECTORYX := DIRECTORY /NODATE /NOHEADING /NOTRAILING
DIR_OUTPUT_FILENAME = "TOPAS$UTILLOG:" + F$UNIQUE() + ".TMP"
DEVICE = $1$DGA1112
DIRECTORYX 'DEVICE':[000000...]*.*;* /NOSIZE /OUTPUT='DIR_OUTPUT_FILENAME'

与此同时,我有一些我不感兴趣的文件报告给我。在这种情况下,我想从TMP文件中删除任何可能包含此文件名( filename.ext; )的行,以便批处理脚本可以继续通过它,并且只报告我不明确的文件忽略。

如何在循环内部使用'IGNORE_FILE'作为文本字符串的变量来匹配并删除相关的文本行,以便当我的批处理脚本继续执行文件时,它将不会报告文件要求被忽略。

非常感谢您的帮助

2 个答案:

答案 0 :(得分:1)

这两条评论都是一个很好的开始。仔细检查。 哪个OpenVMS版本?过去20年的事情?

抓住并使用DFU!

$ define/user sys$output nl:
$ mcr dfu searc/versio=min=200/excl=(*.dat,*.tmp)/form="!AS"/out=tmp.tmp dka0:
$ type tmp.tmp
BUNDY$DKA0:[SYS0.SYSMGR]OPERATOR.LOG;242
BUNDY$DKA0:[SYS0.SYSMGR]ACME$SERVER.LOG;241
BUNDY$DKA0:[SYS0.SYSMGR]LAN$ACP.LOG;241

您还可以考虑在循环中粘贴F $ SEARCH并解析版本和其他有趣的组件以实现您的排除....

$
$ type SEARCH_HIGH_VERSION.COM
$ max = 200
$ old = ""
$ IF p1.EQS."" THEN EXIT 16 ! PARAM
$loop:
$ file = F$SEARC(p1)
$ IF file.EQS."" THEN EXIT 99018 ! NMF
$ IF file.EQS.old THEN EXIT 100164 ! Not wild
$ old = file
$ version = F$PARSE(file,,,"VERSION") - ";"
$ IF max.GE.'version' THEN GOTO loop
$ ! IF ... further string tests
$ WRITE SYS$OUTPUT file
$ GOTO LOOP
$
$ @SEARCH_HIGH_VERSION.COM *.*;*
SYS$SYSROOT:[SYSMGR]ACME$SERVER.LOG;241
SYS$SYSROOT:[SYSMGR]LAN$ACP.LOG;241
SYS$SYSROOT:[SYSMGR]OPERATOR.LOG;242
SYS$SYSROOT:[SYSMGR]TMP.TMP;304
SYS$SYSROOT:[SYSMGR]TMP.TMP;303
SYS$SYSROOT:[SYSMGR]TMP.TMP;302
SYS$SYSROOT:[SYSMGR]TMP.TMP;301
SYS$SYSROOT:[SYSMGR]TMP.TMP;300
%RMS-E-NMF, no more files found
$
$ @SEARCH_HIGH_VERSION.COM tmp.tmp
SYS$SYSROOT:[SYSMGR]TMP.TMP;304
%RMS-F-WLD, invalid wildcard operation
$

DFU可能比DIR快10 * DIR将比F $ SEARCH快10倍,但在处理过程中你会松动它。

祝你好运! 海因

答案 1 :(得分:1)

好吧......现在我知道你来自哪里了。

  
    
      

我如何编写从第7行到结尾的所有内容?

    
  

嗯,你可以用i = 7循环开始,或者你可以使用"引用"字符串并使用引号作为新分隔符。以下是两个示例,使用双引号作为几乎自然的第二个分隔符选择

$
$ READ SYS$INPUT BUFF
SHG101,$1$DGA1101:,25,15,10,5000,100,X.TMP,Y.DAT
$
$ excludes = ""
$ tmp = F$ELEMENT(7, ",", BUFF)
$ IF tmp.NES.","
$ THEN
$   i = 8
$   excludes = tmp
$exclude_loop:
$   tmp = F$ELEMENT(i, ",", BUFF)
$   IF tmp.NES.","
$   THEN
$      excludes = excludes + "," + tmp
$      i = i + 1
$      GOTO exclude_loop
$   ENDIF
$   excludes = "/EXCLUDE=(" + excludes + ")"
$ ENDIF
$
$ SHOW SYMB excludes
$
$! Using a different delimitor:
$ READ SYS$INPUT BUFF
SHG101,$1$DGA1101:,25,15,10,5000,100,"X.TMP,Y.DAT"
$
$ excludes = ""
$ tmp = F$ELEMENT(1, """", BUFF)
$ IF tmp.NES."," THEN excludes = "/EXCLUDE=(" + tmp + ")"
$
$ SHOW SYMB excludes

在我们看到的代码中: 检查'设备'对于高文件版本(> =;'' HVERNO') - 可能需要一些时间......>

我劝你看看DFU 大循环代码" READ FH3 / END_OF_FILE = LABEL $ _EOF_DIRLIST1 BUFF2 ... " 将简化为:

dfu searc/versio=min=200'excludes'form="!AS"/out=tmp.tmp dka0:

无论有多少文件,这都会在几秒钟内完成。 抛出整个警告的东西,包括它总是检查32000,因为它(几乎)免费。 执行DFU命令后,创建“幻想”'输出如果tmp.tmp不为空,则创建标题并附加tmp.tmp。始终删除tmp.tmp($ CLOSE / DISP = DELETE)

免费咨询......

这15个深度嵌套的IF-THEN-ELSE-ENDIF接收消息看起来很糟糕(维护) 考虑一个数组查找?! 这是一个成功的例子:

$! prep for test
$ EL = p1
$ EL_DIAG = "FILE.DAT"
$ LOCAL_STATUS = "12345"
$
$! Code snippet to be tested
$
$ x  = 'EL'
$ ! Fold multiple conditions into 1 message
$
$ if  (EL .EQ. 7) .OR. (EL .EQ. 14) .OR. (EL .EQ. 21) .OR. (EL .EQ. 25) -
                .OR. (EL .EQ. 29) .OR. (EL .EQ. 30)  THEN x = "L1"
$
$ MSG_6     = "error opening "       + EL_DIAG + " for WRITE (RM=" + LOCAL_STATUS + ")"
$ IDT_6     = "OPENIN"
$ MSG_L1    = "error reading from "  + EL_DIAG + " (RM=" + LOCAL_STATUS + ")"
$ IDT_L1    = "READERR"
$ MSG_8     = "device name missing " + EL_DIAG
$ IDT_8     = "DNNF"
$
$ ! Pick up the required texts
$
$ IF F$TYPE(MSG_'x').EQS.""
$ THEN
$   WRITE SYS$OUTPUT "No message found for code: ", EL
$   EXIT 16
$ ENDIF
$
$ MSG   = MSG_'x
$ IDTXT = IDT_'x
$
$ WRITE SYS$OUTPUT "MSG  : ", MSG
$ WRITE SYS$OUTPUT "IDTXT: ", IDTXT

干杯, 海因