sed 这个命令,作为linux 运维会经常用到,但是由于参数比较多,而且我们用到的会比较固定。
删除/etc/passwd中的第15行
sed -i '1d' passwd
删除/etc/passwd中的 最后一行
删除/etc/passwd中的8行到14行的所有内容
sed -i '8,14d' passwd
删除/etc/passwd中的不能登录的用户(筛选条件:/sbin/nologin)
sed -i '/\/sbin\/nologin/d' passwd
删除/etc/passwd 带ftp的所有行
sed -i '/^ftp/d' passwd
删除/etc/passwd中以mail开头的行,到以ftp开头行的所有内容
sed -i '/^mail/,/^ftp/d' passwd
删除/etc/passwd中第一个不能登录的用户 到 第13行的所有内容
这个表达式会删除第一个 /sbin/nologin 到 第13行,然后再重新开始再次删除,循环。。。,不建议使用
sed -i '/\/sbin\/nologin/,13d' passwd
删除/etc/passwd中第5行到以ftp开头的所有行的内容
sed -i '5,/^ftp/d' passwd
删除/etc/passwd中以nobody开头的行到最后行的所有内
sed -i '5,/^ftp/d' passwd
删除/etc/passwd中以nobody开头的行到最后行的所有内
sed -i '/^nobody/,$d' passwd
典型需求:
删除nginx.conf文件中注释行和空行
sed -i '/^#/d;/^$/d' nginx.conf
删除一个或多个空格加 # 号的行
sed -i '/[:blank:]*#/d' nginx.conf
在配置文件中所有不以#开头的行前面添加*符号,注意:以#开头的行不添加
^[^#] 对以#号开头的行取反就是非#开头的行,& 是反向引用代表前面的行,然后加*
sed -i 's/^[^#]/*&/g' nginx.conf
sed 命令参数参数说明
[root@centos-site24 sh]# sed -h
sed:无效选项 -- h
用法: sed [选项]... {脚本(如果没有其他脚本)} [输入文件]...
-n, --quiet, --silent
取消自动打印模式空间
-e 脚本, --expression=脚本
添加“脚本”到程序的运行列表
-f 脚本文件, --file=脚本文件
添加“脚本文件”到程序的运行列表
--follow-symlinks
直接修改文件时跟随软链接
-i[SUFFIX], --in-place[=SUFFIX]
edit files in place (makes backup if SUFFIX supplied)
-c, --copy
use copy instead of rename when shuffling files in -i mode
-b, --binary
does nothing; for compatibility with WIN32/CYGWIN/MSDOS/EMX (
open files in binary mode (CR+LFs are not treated specially))
-l N, --line-length=N
指定“l”命令的换行期望长度
--posix
关闭所有 GNU 扩展
-r, --regexp-extended
在脚本中使用扩展正则表达式
-s, --separate
将输入文件视为各个独立的文件而不是一个长的连续输入
-u, --unbuffered
从输入文件读取最少的数据,更频繁的刷新输出
-z, --null-data
separate lines by NUL characters
--help
display this help and exit
--version
output version information and exit
如果没有 -e, --expression, -f 或 --file 选项,那么第一个非选项参数被视为
sed脚本。其他非选项参数被视为输入文件,如果没有输入文件,那么程序将从标准
输入读取数据。
GNU sed home page: <http://www.gnu.org/software/sed/>.
General help using GNU software: <http://www.gnu.org/gethelp/>.
Comments | NOTHING