shell脚本编写汇集
一、替换文本:
##1
sed -i 's/disabled=true/disabled=false/' /etc/fdfs/storage.conf
##2
sed -i 's/base_path=\/home\/yuqing\/fastdfs/base_path=\/fdfs\/storage/' /etc/fdfs/storage.conf
##3
echo "Enter Tracker_IP : "
read Tracker_IP
echo "$Tracker_IP"
sed -i "/tracker_server/ s/192.168.209.121/$Tracker_IP/" /etc/fdfs/storage.conf
##4 假设上面的tracker_server在源文件里的值不是固定的。应改成以下的写法:
echo "Enter Tracker_IP : "
read Tracker_IP
echo "$Tracker_IP"
sed -i "/tracker_server/ s/\(.*=\).*/\1$Tracker_IP/" /etc/fdfs/storage.conf
## 这样写法是不正确的 :
sed -i "s/tracker_server=192.168.209.121/tracker_server=$Tracker_IP/" /etc/fdfs/storage.conf
二、插入文本:
下面命令能够在b_IPadress 192.168.1.188该行后插入指定的一行或多行文本
sed -i '/b_IPadress 192.168.1.188/a\test123' /root/my/myBin/sbin/test.config
sed -i '/b_IPadress 192.168.1.188/s/$/\nline1\nline2/' /root/my/myBin/sbin/test.config
sed -i '/b_IPadress 192.168.1.188/a\test123\n123\n123\n123' /root/my/myBin/sbin/test.config
假设把中间的a换成i则是在b_IPadress 192.168.1.188这一行前面插入多行
三、单引號与双引號:
单引號是强引用,引號里的值是什么,变量的值就是什么;
双引號是弱引用。引號里的值若再包括变量,那在赋值的时候,全部这些变量就被马上替换了。
比如:
echo "who am i:$LOGNAME" 结果:who am i:yeexun
echo "who am i:'$LOGNAME'" 结果:who am i:'yeexun'
echo "who am i:"$LOGNAME"" 结果:who am i:yeexun
echo 'who am i:$LOGNAME' 结果:who am i:$LOGNAME
echo 'who am i:"$LOGNAME"' 结果:who am i:"$LOGNAME"
echo 'who am i:'$LOGNAME'' 结果:who am i:yeexun
四、依据字符串获取当前行号并赋给一变量,然后依据获得的变量行号插入文本
1、获取行号赋值变量
myline=$(awk '/test123/ {print NR}' /root/my/myBin/sbin/test.config)
2、依据行号变量插入文本
sed -i '3s/$/&\a123/' a.txt
sed -i ''$myline's/$/&\a\nupstream fdfs_group1 {\n server '$tempvar':8080;/' /root/my/myBin/sbin/test.config
sed ‘3a 123’ 1.txt
sed -i ''$myline'a\nupstream fdfs_group1 {\n server '$tempvar':8080;' /root/my/myBin/sbin/test.config
五、变量的运算
应把运算放入方括号内
已知变量myline,该变量加2应写为:$[myline+2]
六、替换第几次出现的某个字符串的值
无限制:
sed -e ':a;/\(.*ABC\)\{3\}/{s/ABC/DEF/3;q};N;b a'
ABC表示替换前的数据,DEF是替换后的数据,3是第几次出现
有限制(如:title abcdefg。不能有=。仅仅能为空格)
替换指定行的数据:sed '0,/title/ s/\(title \).*/\1hello/' urfile
当中0表示在文本中第一次出现
七、替换指定行的数据
sed -i '2c\storage_server_port=11111' /root/my/myBin/snbin/temp2
八、变量保存文件总行数
temp=`grep -c . /root/my/myBin/snbin/temp2`
九、删除文件最后几行
删除最后一行:sed -e '$d' file
删除最后几行:用for循环加上面的语句
十、其他
shell赋值时。等号前后不能有空格
if条件中应这样: if 空格 [ 空格$tempvar0空格==空格"N"空格 ]
基础知识:http://bbs.chinaunix.net/thread-452942-1-1.html
shell脚本编写汇集的更多相关文章
- shell脚本编写方法
shell脚本编写就如同一门语言,涉及到运行环境.基本语法.变量定义.函数.参数(系统参数).条件判定.执行流程控制 等等问题. 本文就以下几个方面进行描述: 运行环境: shell shebang ...
- 7. Shell 脚本编写
一.Shell 脚本编写 1.提示用户输入一个字符串,如果是 hello,打出 yes,并每秒输出 "hello,world",否则就输出 no,实现如下: #!/bin/bash ...
- Shell awk文本处理,shell脚本编写
Shell awk文本处理,shell脚本编写 一:内容包含awk.变量.运算符.if多分支 <a>语法糖: awk [options] 'commands' files option - ...
- shell脚本编写mind
首先我们要缩小这个问题的范围 如果在面试中被问到这样的问题,说说shell脚本编写思路 如:你是在公司主要负责zabbix监控的 对答如下:shell脚本这个说法挺广的,您看我这么跟您说吧,我在平时工 ...
- 基于数组的shell脚本编写
基于数组的shell脚本编写 2017年08月17日 22:56:36 momokuku123 阅读数:369 数据:变量,文件,数组 变量:存储单个元素的内存中的一块存储空间 数组:存储多个元素的内 ...
- shell脚本编写nginx部署脚本
下面为shell脚本编写的nginx的安装及修改nginx.conf的脚本,脚本比较简单: #!/bin/bash function yum_install(){ yum install epel-r ...
- shell脚本编写自动启动服务方法
shell脚本编写自动启动服务方法 前言 ln :创建连接文件 默认创建的是硬连接,好比复制 ,但是两个文件会同步命令:ln ./java/android/aa.txt aaa s :创建的是软连接变 ...
- shell脚本编写笔记
包含转载内容,转载自http://wenku.baidu.com/link?url=jtCHxEYzgGve6P64U3JRQRgU6nhpGvqFLLpWu9I2Htq6hi9TGLudRFkk7r ...
- shell脚本编写步骤及其常用命令和符号
1,什么是Shell Shell 是kernel的一个外壳,是一个命令解析器,负责用户与内核的交互.2,Shell脚本 Shell脚本类似于批处理,可以方便的执行大量命令.3,编写sh ...
随机推荐
- Navicat 选择语句
1.进入数据库后,点击Query 2.点击new query 3.左边提供界面的筛选条件,如果不清楚sql语句,可直接在上面操作 4.右边可自己编写sql语句 5.写完语句后,点击Run,在resul ...
- javascript小数相减会出现一长串的小数位数的原因
javascript小数相减会出现一长串的小数位数的原因 <script> var a='38.8'; var b='6.8'; alert(parseFloat(a)-parseFloa ...
- mysql中explain优化分析
效率比较 range >index > all
- 初学Javascript对象
<script> var p=new Object(); //属性 p.width=; p.height=; p.num=; p.autotime=; //方法 p.autoplay=fu ...
- Linux 下 安装 Phalcon
先安装GIT 然后从 git://github.com/phalcon/cphalcon.git 这里下载安装文件 编译完成就可以安装了! 编译chmod -R 777 cphalcon1. 创建从C ...
- java jdbc 连接mysql 数据库
JDBC连接MySQL 加载及注册JDBC驱动程序 Class.forName("com.mysql.jdbc.Driver"); Class.forName("com. ...
- mysql 表格中的数据量过大,修改数据库字段信息会花费很长的时间
遇到几百万的数据操作遇到很多问题,比如分区,比如分表,sql语句的效率问题.努力学习好mysql优化还是很有必要的.
- Python学习笔记六--文件和输入输出
6.1文件对象 所有Python对文件的操作都是基于对文件对象的操作.那么就从文件对象的创建说起.open()[file()]提供初始化输入输出的接口.open()成功打开文件时会返回一个文件对象. ...
- [转] .NET 3.5中MSChart组件的ImageLocation属性含义
在.NET程序/网站中如果要生成统计图表/图形,以前可以采用OWC(Office Web Components),如OfficeXP组件OWC10.Office2003组件OWC11.OWC采用COM ...
- poj 2782 Bin Packing (贪心+二分)
F - 贪心+ 二分 Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Description ...