如何将字符串中的左边部分和右边部分剥离到匹配表达式,就像在ksh中一样?
例如:
${name##*/}
${name%/*}
Run Code Online (Sandbox Code Playgroud)
(有关ksh示例,请参阅http://www.well.ox.ac.uk/~johnb/comp/unix/ksh.html).
我似乎无法弄清楚使用re模块或字符串模块这样做的简单方法,但我必须遗漏一些东西.
set -o vi-tabcomplete 正在启用标签自动填充功能
和
set -o emacs 正在打开历史记录(上一个命令,下一个命令)
但是,如果我在〜/ .kshrc中设置它们,它只打开一个emacs(历史记录),我无法启用标签自动完成功能.我错过了什么吗?
set -o vi-tabcomplete
set -o emacs
Run Code Online (Sandbox Code Playgroud)
做了以下
set -o emacs
Esc, Ctrl V -- This gave me
$ Version AJM 93t+ 2010-02-02
Run Code Online (Sandbox Code Playgroud)
还试过做
$ set -o emacs
$ bind "^I=complete"
ksh: bind: not found [No such file or directory]
Run Code Online (Sandbox Code Playgroud)
还把这些东西放在.kshrc中
set -o emacs
bind "^I=complete"
Run Code Online (Sandbox Code Playgroud)
现在,只有历史才有用,而不是标签完整.
这可能是显而易见的,但Google似乎让我失望了.我需要在Unix(AIX,ksh)上创建一个具有任意名称的零字节文件.做这件事的好命令是什么.我可以写一些明显的脚本.
只是为了清楚我没有做任何愚蠢的事情.这是一个生成某些测试场景的脚本.(处理0字节文件时检查正确的行为.)
我编写了以下脚本,如果 grep 在文件中找不到相关字符串,它会启用 20 秒的超时。
该脚本运行良好,但脚本的输出是这样的:
./test: line 11: 30039: Killed
Run Code Online (Sandbox Code Playgroud)
如何从 kill 命令中禁用此消息?
如果进程不存在,如何告诉kill命令忽略?
THX
耶尔
#!/bin/ksh
( sleep 20 ; [[ ! -z ` ps -ef | grep "qsRw -m1" | awk '{print $2}' ` ]] && kill -9 2>/dev/null ` ps -ef | grep "qsRw -m1" | awk '{print $2}' ` ; sleep 1 ) &
RESULT=$!
print "the proccess:"$RESULT
grep -qsRw -m1 "monitohhhhhhhr" /var
if [[ $? -ne 0 ]]
then
print "kill "$RESULT
kill -9 …Run Code Online (Sandbox Code Playgroud) 嗨我正在尝试使用awk命令找到正则表达式后打印5行.我有以下内容:
line_start=$(awk '/regex/{print NR}' file)
let line_end=$line_start+4
awk 'NR==$line_start, NR==$line_end' file
Run Code Online (Sandbox Code Playgroud)
这不会打印任何东西.它没有挂起,只是继续下一行.
我研究了一些类似的问题,并看到人们使用-v选项.我应该在这里使用它,他们的情况是更大的awk脚本.
顺便说一下,我正在使用Kornshell
谢谢!
我想将命令的结果存储到我的shell脚本中的变量中.我似乎无法让它工作.我想要目录中最近日期的文件.
PRODUCT= 'ls -t /some/dir/file* | head -1 | xargs -n1 basename'
Run Code Online (Sandbox Code Playgroud)
它不会工作
我遇到了ksh脚本中的行,这些脚本声明了一个变量并在同一行上提供了另一个shell脚本.例如:
MYVARIABLE="abc" . ~core/script.sh
Run Code Online (Sandbox Code Playgroud)
这是否会产生与单独声明它们不同的行为?例如:
MYVARIABLE="abc"
. ~core/script.sh
Run Code Online (Sandbox Code Playgroud) 我注意到 KSH 和 Bash 之间的差异,并且我正在寻找记录该差异的位置,或者可能确认其中一个是错误。
在 Korn Shell 中(在 KSH88 和 KSH93 上看到),此命令运行良好,并打印结果“yes”:
if [[ -z "" ]] then echo yes ; fi # Note no ';' after the ']]'
Run Code Online (Sandbox Code Playgroud)
在 Bash 中,我得到一个syntax error near unexpected token 'then'.
仅当我使用双括号时才会出现此行为。如果我使用单括号形式的条件表达式,KSH 和 Bash 都会给我一个没有分号的语法错误,但会抱怨 而fi不是then.
这是一个错误还是一个功能?在 ksh 或 Bash 中?我注意到 Bash 和 ksh 的手册页的 语法略有不同if,但这种差异似乎不适用于这种情况。
编辑:bash有人(@jp48)指出了和手册页之间语法定义的显着差异ksh。然而,查看与AST源代码匹配的 Solaris (11.3)手册页,语法为:
if list ;then list [ ;elif list ;then list …Run Code Online (Sandbox Code Playgroud) 我的 ksh 脚本中有下面的代码片段。有没有一种方法可以让我获得 sftp 是否成功执行并将文件从源复制到目标目的地的返回代码?
echo "sftp start" >> /test/logfile.log
sftp user@server <<EOF >> /test/logfile.log
cd /tgt/files
lcd /src/files
rm *.csv
put -p *.csv
exit
EOF
echo "sftp end" >> /test/logfile.log
Run Code Online (Sandbox Code Playgroud) 我有两个正在处理的文件。第一个文件是我必须搜索的主数据库文件。第二个文件是我可以创建的文件,它允许我从主数据库中命名我想要提取的项目。我设法制作了一个 AWK 解决方案,它将搜索主数据库并提取与第二个文件匹配的确切行。但是,我无法弄清楚如何将匹配后的行复制到我的新文件中。
主数据库看起来像这样:
40005X/50005/60005/3/10/9/
10038A/20038/30038/0/5/23./XXXX/
10039A/20039/30039/0/5/23./XXXX/
10040A/20040/30040/0/5/23./XXXX/
10041A/20041/30041/0/5/23./XXXX/
10042A/20042/30042/0/5/23./XXXX/
10043A/20043/30043/0/5/23./XXXX/
10044A/20044/30044/0/5/23./XXXX/
10045A/20045/30045/0/5/23./XXXX/
10046A/20046/30046/0/5/23./XXXX/
40006X/50006/60006/3/10/3/
10047A/20047/30047/0/5/23./XXXX/
10048A/20048/30048/0/5/23./XXXX/
10049A/20049/30049/0/5/23./XXXX/
40007X/50007/60007/3/10/3/
10050A/20050/30050/0/5/23./XXXX/
10051A/20051/30051/0/5/23./XXXX/
10052A/20052/30052/0/5/23./XXXX/
40008X/50008/60008/3/10/1/
10053A/20053/30053/0/5/23./XXXX/
40009X/50009/60009/3/10/3/
10054A/20054/30054/0/5/23./XXXX/
10055A/20055/30055/0/5/23./XXXX/
10056A/20056/30056/0/5/23./XXXX/
40010X/50010/60010/3/10/3/
10057A/20057/30057/0/5/23./XXXX/
10058A/20058/30058/0/5/23./XXXX/
10059A/20059/30059/0/5/23./XXXX/
Run Code Online (Sandbox Code Playgroud)
在我的示例中,以 4000 开头的行是我匹配的第一行。该行的最后一个数字告诉我要复制多少行。因此,在第一行中40005X/50005/60005/3/10/9/,我将匹配 40005X,该行中的 9 告诉我下面有 9 行需要与它一起复制。
第二个文件非常简单,看起来像这样:
40005X
40007X
40008X
Run Code Online (Sandbox Code Playgroud)
当脚本找到每个匹配项时,我想将信息从第一个文件移动到一个新文件以进行分析。最终结果如下所示:
40005X/50005/60005/3/10/9/
10038A/20038/30038/0/5/23./XXXX/
10039A/20039/30039/0/5/23./XXXX/
10040A/20040/30040/0/5/23./XXXX/
10041A/20041/30041/0/5/23./XXXX/
10042A/20042/30042/0/5/23./XXXX/
10043A/20043/30043/0/5/23./XXXX/
10044A/20044/30044/0/5/23./XXXX/
10045A/20045/30045/0/5/23./XXXX/
10046A/20046/30046/0/5/23./XXXX/
40007X/50007/60007/3/10/3/
10050A/20050/30050/0/5/23./XXXX/
10051A/20051/30051/0/5/23./XXXX/
10052A/20052/30052/0/5/23./XXXX/
40008X/50008/60008/3/10/1/
10053A/20053/30053/0/5/23./XXXX/
Run Code Online (Sandbox Code Playgroud)
我目前拥有的与第一行匹配的代码是这样的:
#! /bin/ksh
file1=input_file
file2=input_masterdb
file3=output_test
awk -F'/' 'NR==FNR {id[$1]; next} $1 in id' $file1 $file2 > …Run Code Online (Sandbox Code Playgroud)