可以复习一下xargs的用法,和变量的一些高级操作技巧
如何批量把若干文件从一个扩展名改为另一个扩展名?比如把后缀gz,改为zip
答:
1.for file in *.gz; do mv $file `basename $file .gz`.zip; done
或(也适合ksh)
for file in *.gz; do mv $file $.zip; done
2.ls | grep gz | awk -F'.' '{print }'|xargs -i mv {}.gz {}.zip
附netman十三问片断:
$:拿掉第一条 / 及其左边的字符串:dir1/dir2/dir3/my.file.txt
$:拿掉最后一条 / 及其左边的字符串:my.file.txt
$:拿掉第一个 . 及其左边的字符串:file.txt
$:拿掉最后一个 . 及其左边的字符串:txt
$:拿掉最后条 / 及其右边的字符串:/dir1/dir2/dir3
$:拿掉第一条 / 及其右边的字符串:(空值)
$:拿掉最后一个 . 及其右边的字符串:/dir1/dir2/dir3/my.file
$:拿掉第一个 . 及其右边的字符串:/dir1/dir2/dir3/my
记忆的方法为:
# 是去掉左边(在鉴盘上 # 在 $ 之左边)
% 是去掉右边(在鉴盘上 % 在 $ 之右边)
单一符号是最小匹配﹔两个符号是最大匹配。
$:提取最左边的 5 个字节:/dir1
$:提取第 5 个字节右边的连续 5 个字节:/dir2
我们也可以对变量值里的字符串作替换:
$:将第一个 dir 提换为 path:/path1/dir2/dir3/my.file.txt
$:将全部 dir 提换为 path:/path1/path2/path3/my.file.txt
利用 ${ } 还可针对不同的变量状态赋值(没设定、空值、非空值):
$ :假如 $file 没有设定,则使用 my.file.txt 作默认值。(保留空值及非空值)
$ :假如 $file 没有设定或为空值,则使用 my.file.txt 作默认值。 (保留非空值)
$ :不管 $file 为何值,均使用 my.file.txt 作默认值。 (不保留任何值)
$ :若 $file 为非空值,则使用 my.file.txt 作传回值。 (保留没设定及空值)
$ :若 $file 没设定,则使用 my.file.txt 作默认值,同时将 $file 定义为非空值。 (保留空值及非空值)
$ :若 $file 没设定或为空值,则使用 my.file.txt 作默认值,同时将 $file 定义为非空值。 (保留非空值)
$ :若 $file 没设定,则将 my.file.txt 输出至 STDERR。 (保留空值及非空值))
$ :若 $file 没设定或为空值,则将 my.file.txt 输出至 STDERR。 (保留非空值)
还有哦,$ 可计算出变量值的长度:
$ 可得到 27 ,因为 /dir1/dir2/dir3/my.file.txt 刚好是 27 个字节...
接下来,再为大家介稍一下 bash 的组数(array)处理方法。
一般而言,A="a b c def" 这样的变量只是将 $A 替换为一个单一的字符串,
但是改为 A=(a b c def) ,则是将 $A 定义为组数...
bash 的组数替换方法可参考如下方法:
$ 或 $ 可得到 a b c def (全部组数)
$ 可得到 a (第一个组数),$ 则为第二个组数...
$ 或 $ 可得到 4 (全部组数数量)
$ 可得到 1 (即第一个组数(a)的长度),$ 可得到 3 (第四个组数(def)的长度)
A[3]=xyz 则是将第四个组数重新定义为 xyz ...
shell问答
- oneleaf
- 论坛管理员
- 帖子: 10441
- 注册时间: 2005-03-27 0:06
- 系统: Ubuntu 12.04
16:批量修改文件名后缀
当净其意如虚空,远离妄想及诸取,令心所向皆无碍
- oneleaf
- 论坛管理员
- 帖子: 10441
- 注册时间: 2005-03-27 0:06
- 系统: Ubuntu 12.04
17:用join比较处理某些字段相同的文件
问:
# cat aa
123|11|aaaaa
124|12|abasf
125|12|aaccc
126|13|ccccc
127|14|ccvvv
128|17|vgfgd
# cat bb
12|aaa
12|ddd
13|aaa
14|aaa
要生成
124|12|abasf
124|12|abasf
125|12|aaccc
125|12|aaccc
126|13|ccccc
127|14|ccvvv
既将aa中第二域与bb中第一域相同的记录打印出来,怎样实现?
答案:
1.join -2 1 -1 2 1 2 -t'|' -o 1.1,1.2,1.3
2.for line in `<a.txt` ;do key=`echo $line|cut -d '|' -f2`; [ -z "`grep $key b.txt`" ]||echo $line; done
3.awk的方法
A:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
{ if( in lines)
print }' aa.txt
以上运行结果为aa.txt在bb.txt存在的。
B:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
{ if( in lines)
next
else
print }' aa.txt
以上运行结果为aa.tt在bb.tt不存在的。
C:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
{ if( in lines)
print "|find"
else
print "|not find" }' aa.txt
以上运行结果为aa.txt在bb.txt中找到的打印find,没有找到的打印not find。
# cat aa
123|11|aaaaa
124|12|abasf
125|12|aaccc
126|13|ccccc
127|14|ccvvv
128|17|vgfgd
# cat bb
12|aaa
12|ddd
13|aaa
14|aaa
要生成
124|12|abasf
124|12|abasf
125|12|aaccc
125|12|aaccc
126|13|ccccc
127|14|ccvvv
既将aa中第二域与bb中第一域相同的记录打印出来,怎样实现?
答案:
1.join -2 1 -1 2 1 2 -t'|' -o 1.1,1.2,1.3
2.for line in `<a.txt` ;do key=`echo $line|cut -d '|' -f2`; [ -z "`grep $key b.txt`" ]||echo $line; done
3.awk的方法
A:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
{ if( in lines)
print }' aa.txt
以上运行结果为aa.txt在bb.txt存在的。
B:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
{ if( in lines)
next
else
print }' aa.txt
以上运行结果为aa.tt在bb.tt不存在的。
C:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
{ if( in lines)
print "|find"
else
print "|not find" }' aa.txt
以上运行结果为aa.txt在bb.txt中找到的打印find,没有找到的打印not find。
当净其意如虚空,远离妄想及诸取,令心所向皆无碍
- oneleaf
- 论坛管理员
- 帖子: 10441
- 注册时间: 2005-03-27 0:06
- 系统: Ubuntu 12.04
- id_sonic
- 帖子: 339
- 注册时间: 2005-04-08 18:08
- 来自: Chongqing
- 联系:
Re: shell问答
oneleaf 写了: 解决办法:
1.grep 'REPORT COUNT= 22985' -B5 -C1 youfile >newfile
2.cat $scr_file|awk 'BEGIN~/REPORT COUNT= 22985/ &print >'$dest_file'}'
3.awk 'BEGIN/REPORT COUNT= 22985/{print >"newfile"}' file
4.awk ' { for (i=7;i>0;i--);a[1]=;if (a[2]~/REPORT COUNT= 22986/){for (i=7;i>0;i--){print a}}}' yourfile >newfile
2,3 两种 好像不对啊