[英]Find multiple strings between values and replace with newline in bash
我需要編寫一個bash腳本以列出sql數據庫中的值。
到目前為止,我已經走了,但現在我需要繼續做下去。
到目前為止的字符串是
10.255.200.0/24";i:1;s:15:"10.255.207.0/24";i:2;s:14:"192.168.0.0/21
現在,我需要刪除語音標記之間的所有內容並將其發送到新行。
所需的輸出:
10.255.200.0/24
10.255.207.0/24
192.168.0.0/21
任何幫助將不勝感激。
$ tr '"' '\n' <<< $string | awk 'NR%2'
10.255.200.0/24
10.255.207.0/24
192.168.0.0/21
您可以使用:
echo 'INPUT STRING HERE' | sed $'s/"[^"]*"/\\\n/g'
說明:
sed 's/<PATTERN1>/<PATTERN2/g'
:用PATTERN2
替換每次出現的PATTERN1
[^"]*
:任何不是"
字符,任何時間 \\\\\\n
:sed中換行符的語法( 在此處參考 ) 考慮到您的Input_file與所示示例相同,那么您可以嘗試以下操作。
awk '
{
while(match($0,/[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+\/[0-9]+/)){
print substr($0,RSTART,RLENGTH)
$0=substr($0,RSTART+RLENGTH)
}
}' Input_file
這可能對您有用(GNU sed):
sed 's/"[^"]*"/\n/g' file
或與Bash一起使用:
sed $'/"[^"]*"/\\n/g' file
或使用其他大多數sed:
sed ':a;/"[^"]*"\(.*\)\(.\|$\)/{G;s//\2\1/;ba}' file
這使用了無保留空間包含換行符的功能。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.