sed是一個很好的文件處理工具,自己是一個管道命令,主要是以行爲單位進行處理,能夠將數據行進行替換、刪除、新增、選取等特定工做,下面先了解一下sed的用法。java
調用sed命令有兩種形式:mysql
sed [options] 'command' file(s) sed [options] -f scriptfile file(s)
經常使用選項:正則表達式
-n∶使用安靜(silent)模式。在通常sed 的用法中,全部來自 STDIN的資料通常都會被列出到螢幕上。但若是加上 -n 參數後,則只有通過sed特殊處理的那一行(或者動做)纔會被列出來。
-e∶直接在指令列模式上進行 sed 的動做編輯;
-f∶直接將 sed 的動做寫在一個檔案內, -f filename 則能夠執行 filename 內的sed動做;
-r∶sed 的動做支援的是延伸型正規表示法的語法。(預設是基礎正規表示法語法)
-i∶直接修改讀取的檔案內容,而不是由螢幕輸出。 sql
經常使用命令:shell
a∶新增, a 的後面能夠接字串,而這些字串會在新的一行出現(目前的下一行)~
c∶取代, c 的後面能夠接字串,這些字串能夠取代n1,n2 之間的行!
d∶刪除,由於是刪除啊,因此 d後面一般不接任何咚咚;
i∶插入, i的後面能夠接字串,而這些字串會在新的一行出現(目前的上一行);
p∶列印,亦即將某個選擇的資料印出。一般 p 會與參數 sed-n 一塊兒運做~
s∶取代,能夠直接進行取代的工做哩!一般這個 s的動做能夠搭配正規表示法!例如 1,20s/old/new/g 就是啦!數據庫
舉例:ruby
#刪除第一行 sed '1d' abc.file #刪除最後一行 sed '$d' abc.file #刪除第一行到第二行 sed '1,2d' abc.file #刪除第二行到最後一行 sed '2,$d' abc.file #顯示第一行 sed -n '1p' abc.file #顯示最後一行 sed -n '$p' abc.file #顯示第一行到第二行 sed -n '1,2p' abc.file #顯示第二行到最後一行 sed -n '2,$p' abc.file #查詢包括關鍵字ruby所在全部行 sed -n '/ruby/p' abc.file #查詢包括關鍵字$所在全部行,使用反斜線\屏蔽特殊含義 sed -n '/\$/p' abc.file #第一行後增長字符串"drink tea" sed '1a drink tea' abc.file && cat abc.file Hello! drink tea ruby is me,welcome to my blog. end #第一行到第三行後增長字符串"drink tea" sed '1,3a drink tea' abc.file && cat abc.file Hello! drink tea ruby is me,welcome to my blog. drink tea end drink tea #第一行後增長多行,使用換行符\n sed '1a drink tea\nor coffee' abc.file && cat abc.file Hello! drink tea or coffee ruby is me,welcome to my blog. end #第一行代替爲Hi sed '1c Hi' abc.file Hi ruby is me,welcome to my blog. end #第一行到第二行代替爲Hi sed '1,2c Hi' abc.file Hi end #替換一行中的某部分格式:sed 's/要替換的字符串/新的字符串/g' (要替換的字符串能夠用正則表達式) #替換ruby爲bird sed -n '/ruby/p' abc.file | sed 's/ruby/bird/g' #刪除ruby sed -n '/ruby/p' abc.file | sed 's/ruby//g' #將當前目錄下包含ruby串的文件中,ruby字符串替換爲java sed -i "s/ruby/java/g" `grep "ruby" -rl ./` #將某個文件中的jack字符串替換爲tom sed -i "s/ruby/java/g" abc.file #在文件abc.file中最後一行直接輸入"bye" sed -i '$a bye' abc.file && cat abc.file Hello! ruby is me,welcome to my blog. end bye
mysql -h host -P port_number -u username -p password <file_to_execute.sql
給mysql的.sql的腳本文件傳遞參數,只能利用本文1部分介紹的sed在調用mysql執行命令前,把sql文件中的變量值替換掉,而後調用mysql命令執行sql腳本文件。工具
舉例:spa
準備mysql數據庫code
create database if not exists test; use test; drop table if exists demo_table; create table demo_table(a varchar(20),age int);
insertstmt.sql
insert into test.demo_table values(@name,@age); exit
該腳本文件往mysql數據庫test中的表demo_table中插入一條記錄,這條記錄的兩個值都是變量,須要外面傳遞進來
execute.sh
#!/bin/sh NAME="lenmom" AGE=1 # set parameters as sql variables && add them to the first line of t.sql sed -i "1 i\ set @name='$NAME';" insertstmt.sql sed -i "1 i\ set @age=$AGE;" insertstmt.sql # execute sql script mysql -u root < insertstmt.sql # clear sql script variables sed -i "1d" insertstmt.sql sed -i "1d" insertstmt.sql
執行效果: