
我举例说明一下,简单点希望你能理解。
首先,编辑一个脚本
vi bashsh (名字可以自己随便取)
内容
#!/bin/bash (在这个文件声明是那一类脚本类型,这里用的是bash,如果其他语言请自己查找)
echo "hello world" (简单的在脚本里面写了一个输出语句)
然后退出编辑:wq保存 (如果vi不会用可能你需要知道怎么编辑文本)
完成后执行bash bashsh就能看件 hello world 的输出
/ 这个意思是当前的目录,如果想通过这个方式执行脚本的话,需要让脚本有执行权限
命令是 chmod +x bashsh
然后cd到这个脚本的当前目录里面ls 可以看见,然后执行/bashsh 就ok了
上面牵涉到vi 工具,基本命令使用,bash,以及权限,自己想要融会贯通先把这些学一下。
ps:/文件名 no such file or diretory 可能是文件没有执行权限。
windows要导入linux 中可以通过硬盘,u盘等工具导入,“桑巴” = samba 在windows和linux效果也很好,是一种共享方式。对于samba怎么说一时半会说不清楚,你可以baidu,google一下samba的配置方法使用方法,先建议你了解了linux基础后再去学习各种samba 之类的服务。
sed -f filename
$x 就是你要sed 所需的文件名。
这是用的是变量形式,就是 for x do sed -f 中的x
但是,$X 并没有谁传参给它,这语句有问题吧?
要么for $x do sed -f $x ,这样还可以传参过去。
如果你还有其他语句也一起贴出来。
通常有两种方式:
1、使用变量将那些jar包放进去,比如
#!/bin/bash
MYCP=ajar:bjar:cjar:
java -cp "$MYCP"
2、如果那些jar包都在一个路径里面如lib,那么最好去设jre加载的扩展目录如下:
java -Djavaextdirs=lib
前言
本文主要给大家介绍了关于Linux shell用sed批量更改文件名的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
示例
去除特定字符
目标:将 2017-01-01jpg、2018-01-01jpg 改为 20170101jpg、20180101jpg
方法:将所有 - 替换为空
for file in `ls | grep jpg`
do
newfile=`echo $file | sed 's/-//g'`
mv $file $newfile
done
这里使用sed进行标准输出的字符串替换,其通用格式如下:
stdout | sed 's/pattern/replace/'
上述示例中,在末尾添加g用于替换所有匹配项,而不仅仅替换第一个匹配项。
中间插入字符
目标:将 book01txt、paper02txt 改为 book-01txt、paper-02txt
方法:用分组匹配分别获取待插入位置两侧的字符串,再通过反向引用实现替换
for file in `ls | grep txt`
do
newfile=`echo $file | sed 's/\([a-z]\+\)\([0-9]\+\)/\1-\2/'`
mv $file $newfile
done
分析
上述示例首先通过 ls 和 grep 命令得到待改名的文件列表,然后用 sed 命令进行字符串的替换,最后再使用 mv 命令来完成文件名的更改。
获取待改名文件列表的方法有很多,可以通过 find 命令,也可以直接给出字符串,我们将在下文中提到。
注意 for 循环后面的 ls | grep txt,这条命令用两个反单引号括了起来,与 $(ls | grep txt) 的作用相同,被包围的字符串会被当作命令执行,然后返回字符串结果。
文件名包含空格的解决方法
我们可以直接将文件列表写到 for 循环中,而不是通过命令来得到,例如:
for file in "file1 file2 file3"
do
done
可以看到 for 循环是通过空格来分割字符串,因此如果待更改的文件名中包含空格的话,就会被拆分成多个文件名,从而出错。
要解决这个问题,我们可以将 IFS(内部字段分隔符)设置为换行符 \n,这样一来,for 循环就会按行来获取变量的值,确保每次获取的确实是一个完整的文件名。
设置 IFS 变量的命令需要放在 for 循环之前:
IFS=$'\n'
for file in `ls`
do
done
也可以直接使用 while read 命令一次读取一行到变量 file 中:
ls | grep "txt" | while read file
do
done
使用 find 获取文件列表
之前的示例中,我们是通过 ls 命令来获取文件列表。该命令只能获取某个目录的文件,而且没法进行多种条件的筛选。
而一说到文件的查找,不得不提到功能强大的 find 命令。该命令可以在多个层次的目录中查找文件,并能够设定诸如创建时间、文件大小、所有者等多种条件,查找起文件来特别方便灵活。
用 find 命令来获取文件列表,再用 sed 命令配合正则表达式来修改文件名,这两个命令的结合几乎能完成所有常见的批量改名任务。
例如,将所有大于1M,且后缀为txt或jpg的文件,由形如 book_20170101txt、image_20170101jpg 的文件改名为 20170101-booktxt、20170101-imagejpg,代码如下:
for file in `find -size +1M -name "_txt" -o -name "_jpg"`
do
newfile=`echo $file | sed 's/\([a-z]\+\)_\([0-9]\+\)/\2-\1/'`
mv $file $newfile
done
就用ifconfig -a
加个grep命令把需要的信息提取出来就行:
ifconfig -a | grep 'encap\|inet\|MTU'
就这一句在我这裏就可以提取到你说的那些信息了
如果不一样根据你那裏的情况你再具体看下吧
以上就是关于Linux红帽shell编程,在bin目录解析器用到sh和bash,显示脚本用到sh+ 文件名。那bash的咋看 。全部的内容,包括:Linux红帽shell编程,在bin目录解析器用到sh和bash,显示脚本用到sh+ 文件名。那bash的咋看 。、Linux shell 脚本如下: for x do sed -f 脚本名 $x > tmp.$x done 中的$x是什么意思、Linux下如何查看名为start.sh脚本启动的进程,等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)