标签: ksh

ksh风格的左右字符串剥离到匹配的表达式?

如何将字符串中的左边部分和右边部分剥离到匹配表达式,就像在ksh中一样?

例如:

${name##*/}

${name%/*}
Run Code Online (Sandbox Code Playgroud)

(有关ksh示例,请参阅http://www.well.ox.ac.uk/~johnb/comp/unix/ksh.html).

我似乎无法弄清楚使用re模块或字符串模块这样做的简单方法,但我必须遗漏一些东西.

python regex string ksh

5
推荐指数
1
解决办法
866
查看次数

ksh自动完成和以前的命令在一起

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)

现在,只有历史才有用,而不是标签完整.

shell ksh

5
推荐指数
1
解决办法
2万
查看次数

如何在ksh中创建一个0字节的文件.

这可能是显而易见的,但Google似乎让我失望了.我需要在Unix(AIX,ksh)上创建一个具有任意名称的零字节文件.做这件事的好命令是什么.我可以写一些明显的脚本.

只是为了清楚我没有做任何愚蠢的事情.这是一个生成某些测试场景的脚本.(处理0字节文件时检查正确的行为.)

unix ksh

5
推荐指数
2
解决办法
1万
查看次数

kill -9 + 禁用来自 kill 命令的消息(标准输出)

我编写了以下脚本,如果 grep 在文件中找不到相关字符串,它会启用 20 秒的超时。

该脚本运行良好,但脚本的输出是这样的:

./test: line 11: 30039: Killed
Run Code Online (Sandbox Code Playgroud)
  1. 如何从 kill 命令中禁用此消息?

  2. 如果进程不存在,如何告诉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)

linux ksh

4
推荐指数
1
解决办法
6101
查看次数

在AWK命令中将变量传递给NR不起作用

嗨我正在尝试使用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

谢谢!

unix shell awk ksh

4
推荐指数
1
解决办法
1万
查看次数

ksh将命令的结果存储到变量中

我想将命令的结果存储到我的shell脚本中的变量中.我似乎无法让它工作.我想要目录中最近日期的文件.

PRODUCT= 'ls -t /some/dir/file* | head -1 | xargs -n1 basename'
Run Code Online (Sandbox Code Playgroud)

它不会工作

linux command ksh

4
推荐指数
1
解决办法
3万
查看次数

在与另一个脚本相同的行上定义shell脚本变量

我遇到了ksh脚本中的行,这些脚本声明了一个变量并在同一行上提供了另一个shell脚本.例如:

MYVARIABLE="abc" . ~core/script.sh
Run Code Online (Sandbox Code Playgroud)

这是否会产生与单独声明它们不同的行为?例如:

MYVARIABLE="abc"
. ~core/script.sh
Run Code Online (Sandbox Code Playgroud)

unix shell ksh

4
推荐指数
1
解决办法
493
查看次数

为什么“if [[ ... ]] then”(没有分号或换行符)在 ksh 中有效,但在 bash 中无效?

我注意到 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)

bash shell ksh

4
推荐指数
1
解决办法
2238
查看次数

获取 SFTP 命令的返回码

我的 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)

unix sftp ksh

4
推荐指数
1
解决办法
2万
查看次数

如何匹配模式然后复制多行?

我有两个正在处理的文件。第一个文件是我必须搜索的主数据库文件。第二个文件是我可以创建的文件,它允许我从主数据库中命名我想要提取的项目。我设法制作了一个 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)

awk ksh

4
推荐指数
1
解决办法
144
查看次数

标签 统计

ksh ×10

shell ×4

unix ×4

awk ×2

linux ×2

bash ×1

command ×1

python ×1

regex ×1

sftp ×1

string ×1