替换z / OS UNIX文件中的十六进制字符

时间:2018-09-04 13:34:19

标签: unix sed zos

我需要使用z / OS JCL步骤调用的sed非交互式流editoR,将z / OS UNIX文件中的单个LF(x'0A')字符转换为CRLF(x'0D'x'0A')字符。

在这个网站上徘徊,我发现了其他帖子,并且尝试了JCL步骤:

//SEDSTEP  EXEC PGM=BPXBATCH,REGION=0M                              
//STDERR   DD SYSOUT=2                                              
//STDOUT   DD SYSOUT=2                                              
//STDPARM  DD *                                                     
SH sed 's/\x0A/\x0Dx0A/g' </u/sftp/zwnmsft/E/wnmcapdf/arxiu_unix.txt
>/u/sftp/zwnmsft/E/wnmcapdf/arxiu_unix_sed.txt                      
/* 

不幸的是,它无法按预期工作。

任何帮助将不胜感激。

预先感谢

在阅读您的评论后,我添加了此新信息以澄清问题:

1-我尝试转换的文件位于z / OS UNIX中,但包含无法理解的ASCII字符;不是EBCDIC。

2-此文件不包含任何本地EBCDIC换行符X'15'。

3-执行od -cx命令后,我尝试转换的文件如下所示:

ZXDALMA@CIGC:/u/sftp/zwnmsft/E/wnmcapdf> od -cx arxiu_unix.txt              
0000000000   060 061 062 063 064 065 066 067 070 071 012 071 070 067 066 065
                3031    3233    3435    3637    3839    0A39    3837    3635
0000000020   064 063 062 061 060 012                                        
                3433    3231    300A                                        
0000000026

4-如果我执行这样的awk替代方法:

//AWK      EXEC PGM=BPXBATCH,REGION=0M                                  
//STDERR   DD SYSOUT=2                                                  
//STDOUT   DD SYSOUT=2                                                  
//STDPARM  DD *                                                         
SH awk '{ORS=""; gsub("\x0A","\x0D\x0A"); print}'                       
/u/sftp/zwnmsft/E/wnmcapdf/arxiu_unix.txt >                             
/u/sftp/zwnmsft/E/wnmcapdf/arxiu_unix_bis.txt                           
/*    

我得到的期望结果是:

ZXDALMA@CIGC:/u/sftp/zwnmsft/E/wnmcapdf> od -cx arxiu_unix_bis.txt          
0000000000   060 061 062 063 064 065 066 067 070 071  \r 012 071 070 067 066
                3031    3233    3435    3637    3839    0D0A    3938    3736
0000000020   065 064 063 062 061 060  \r 012                                
                3534    3332    3130    0D0A                                
0000000030                                                                 

5,最后-如果我执行sed命令,我得到的信息如下:

ZXDALMA@CIGC:/u/sftp/zwnmsft/E/wnmcapdf> od -cx arxiu_unix_sed.txt          
0000000000   060 061 062 063 064 065 066 067 070 071 012 071 070 067 066 065
                3031    3233    3435    3637    3839    0A39    3837    3635
0000000020   064 063 062 061 060 012  \n                                    
                3433    3231    300A    1500                                
0000000027 

我希望这些外来人口有助于了解我所面临的情况。

Hogstrom发表的评论中新增了一些信息:

这是ls -H命令的输出:

ZXDALMA@CIGC:/u/sftp/zwnmsft/E/wnmcapdf> ls -H arxiu_unix.txt             
-rwxrwxrwx  bin    1 ZWNMSFT  G@PROJ        22 Sep  5 12:17 arxiu_unix.txt   

关于环境变量,这是我执行env命令时的输出:

ZXDALMA@CIGC:/u/sftp/zwnmsft/E/wnmcapdf> env                                    
_BPX_TERMPATH=OMVS                                                              
PATH=/bin:/usr/bin:/usr/lib:/usr/lpp/dfsms/bin:/usr/lpp/java/J7.1_64/bin:/u/zxda
lma::/usr/bin:/usr/lib:/usr/lpp/dfsms/bin                                       
SHELL=/bin/sh                                                                   
PS1=$LOGNAME@$SYS:$PWD>                                                         
COLUMNS=80                                                                      
PS2=>>                                                                          
SYS=CIGC                                                                        
_BPX_SPAWN_SCRIPT=YES                                                           
_=/bin/env                                                                      
_BPXK_SETIBMOPT_TRANSPORT=TCPIP                                                 
STEPLIB=none                                                                    
LOGNAME=ZXDALMA                                                                 
TERM=dumb                                                                       
_BPX_SHAREAS=YES                                                                
HOME=/u/zxdalma                                                                 
LINES=20                                                                        
TZ=MET-1DMET-2,M3.5.0/02:00:00,M10.5.0  

一个重要的细节是,我最近意识到在我们的z / OS UNIX安装中,ESCape字符是[,而不是传统字符。

我已经在终端的底部看到了这个细节,我看到了:

ZXDALMA@CIGC:/u/sftp/zwnmsft/E/wnmcapdf>                                        
 ===>                                                                           
                                                                          INPUT 
ESC=[   1=Help      2=SubCmd    3=HlpRetrn  4=Top       5=Bottom    6=TSO       
        7=BackScr   8=Scroll    9=NextSess 10=Refresh  11=FwdRetr 12=Retrieve  

我也尝试用sed命令代替\;但是,不幸的是,我得到了相同的结果

1 个答案:

答案 0 :(得分:1)

我知道这无法使用sed回答原始问题WRT。我了解您的困境。您正在尝试使用专为EBCDIC设计的工具将ASCII UNIX文本文件转换为大型机上的Windows文本文件!用C编写自己的过滤器很简单。

#include <stdio.h>
#include <stdlib.h>

static void put_char(int c) {
    if (putchar(c) == EOF) {
        fputs("Error: putchar() failed with unexpected EOF", stderr);
        exit(EXIT_FAILURE);
    }
}

int main()
{
    int c;
    while ((c = getchar()) != EOF) {
        if (c == '\x0A') put_char('\x0D');
        put_char(c);
    }
    return 0;
}

测试

DOC:/u/doc/src: >printf "hello word\x0ahello again\x0a" | trlf | hexdump
00000000 88859393 9640A696 99840D0A 88859393 |hello word..hell|
00000010 96408187 8189950D 0A                |o again..       |