2つのファイルがあります:file1
とfile2
。
file1
以下の内容があります。
---
host: "localhost"
port: 3000
reporter_type: "zookeeper"
zk_hosts:
- "localhost:2181"
file2
IPアドレスを含む(1.1.1.1
)
私がやりたいことは、最終結果が次localhost
のように変わることです。1.1.1.1
---
host: "1.1.1.1"
port: 3000
reporter_type: "zookeeper"
zk_hosts:
- "1.1.1.1:2181"
私は試した:
sed -i -e "/localhost/r file2" -e "/localhost/d" file1
sed '/localhost/r file2' file1 |sed '/localhost/d'
sed -e '/localhost/r file2' -e "s///" file1
ただし、ライン全体を交換または変更する必要があるラインの次の行にIPを移動する必要があります。
答え1
解決策は次のとおりですsed
。
% sed -e "s/localhost/$(sed 's:/:\\/:g' file2)/" file1
---
host: "1.1.1.1"
port: 3000
reporter_type: "zookeeper"
zk_hosts:
- "1.1.1.1:2181"
sed -i
これを適切に変更するには、それを使用する必要があります。
利用可能な場合は、awk
次の方法があります。
% awk 'BEGIN{getline l < "file2"}/localhost/{gsub("localhost",l)}1' file1
---
host: "1.1.1.1"
port: 3000
reporter_type: "zookeeper"
zk_hosts:
- "1.1.1.1:2181"
答え2
sed
シェルコマンド置換を使用して、置換文字列を含むファイルを使用する前に読み取ることができます。したがって、sed
一般的な交換が表示されます。
sed "s/localhost/$(cat file2)/" file1 > changed.txt
答え3
私も今日この「問題」に直面しました:テキストブロックを他のファイルの内容に置き換える方法。
私はスクリプトで再利用できるbash関数を作成してこの問題を解決しました。
[cent@pcmk-1 tmp]$ cat the_function.sh
# This function reads text from stdin, and substitutes a *BLOCK* with the contents from a FILE, and outputs to stdout
# The BLOCK is indicated with BLOCK_StartRegexp and BLOCK_EndRegexp
#
# Usage:
# seq 100 110 | substitute_BLOCK_with_FILEcontents '^102' '^104' /tmp/FileWithContents > /tmp/result.txt
function substitute_BLOCK_with_FILEcontents {
local BLOCK_StartRegexp="${1}"
local BLOCK_EndRegexp="${2}"
local FILE="${3}"
sed -e "/${BLOCK_EndRegexp}/a ___tmpMark___" -e "/${BLOCK_StartRegexp}/,/${BLOCK_EndRegexp}/d" | sed -e "/___tmpMark___/r ${FILE}" -e '/___tmpMark___/d'
}
[cent@pcmk-1 tmp]$
[cent@pcmk-1 tmp]$
[cent@pcmk-1 tmp]$ cat /tmp/FileWithContents
We have deleted everyhing between lines 102 and 104 and
replaced with this text, which was read from a file
[cent@pcmk-1 tmp]$
[cent@pcmk-1 tmp]$
[cent@pcmk-1 tmp]$ source the_function.sh
[cent@pcmk-1 tmp]$ seq 100 110 | substitute_BLOCK_with_FILEcontents '^102' '^104' /tmp/FileWithContents > /tmp/result.txt
[cent@pcmk-1 tmp]$
[cent@pcmk-1 tmp]$
[cent@pcmk-1 tmp]$ cat /tmp/result.txt
100
101
We have deleted everyhing between lines 102 and 104 and
replaced with this text, which was read from a file
105
106
107
108
109
110
答え4
試してみてください
join file1 file2
その後、不要なフィールドを削除します。