В качестве упражнения, существует ли метод перенаправления строки в файл без echo? В настоящее время я использую
echo "Hello world" > test.txt
Я знаю о cat
и printf
. Я думал о чем-то вроде
> test.txt <<<"Hello world"
Конечно, это не работает, но, может быть, есть похожая команда?
Вы можете сделать это с "кошка" и здесь-документ.
cat <<EOF > test.txt
some text
EOF
Одной из причин для этого можно было бы избежать любую возможность пароль был виден на выходе из ПС. Однако, в bash и самые современные снаряды, "Эхо" - это встроенная команда, и он выиграл'т показать вверх в ПС выходной, так что, используя что-то вроде это безопасно (не обращая внимание на проблемы с хранением паролей в файлах, конечно):
echo "$password" > test.txt
Существует слишком много способов, чтобы обсуждать то, что вас, вероятно, не волнует. Можно, конечно, взломать - strace bash, или сделать всевозможную черную магию, запустив Bash в gdb.
На самом деле у вас есть два совершенно разных примера. <<<'string'
- это уже запись строки в файл. Если приемлемо что-то кроме printf
, echo
и cat
, вы можете использовать множество других команд, которые ведут себя как cat (sed, awk, tee и т.д.).
$ cp /dev/stdin ./tmpfooblah <<<'hello world'; cat tmpfooblah
hello world
Или ад, в зависимости от того, как вы скомпилировали Bash.
$ enable -f /usr/lib/bash/print print; print 'hello world' >tmpfile
Если вы хотите использовать только строки bash и перенаправление, в чистом bash, без взлома и загружаемых файлов, это невозможно. Однако в ksh93 это возможно.
$ rm tmpfooblah; <<<'hello world' >tmpfooblah <##@(&!()); cat tmpfooblah
hello world
В bash это можно сделать следующим образом
zsh <<< '> test <<< "Hello World!"'
.
Это одно из интересных различий между zsh и bash: при наличии незацепленного >
или >>>
, zsh имеет здравый смысл подключить его к stdin, а bash - нет. Это было бы очень полезно - если бы только было стандартным.
Я пытался использовать это для отправки &append моего ssh-ключа по ssh в удаленный файл authorized_keys
, но удаленный хост был bash, конечно, и ничего не делал.
И вот почему вы должны просто использовать cat
.
awk ' BEGIN { print "Hello, world" } ' > test.txt
сделал бы это
Только перенаправление не сработает, поскольку нечем соединить открытые теперь дескрипторы файлов. Так что нет, такого способа не существует.
Я'вэ решение для bash пуристов. <п>функция 'определение' помогает нам назначить многострочное значение переменной. Это один позиционный параметр: имя переменной присвоить значение.</п> <п>в помощи heredoc, при необходимости там'параметр повторного расширения тоже!</п>
define ()
{
IFS=$'\n' read -r -d '' $1
}
BUCH="Matthäus 1"
define TEXT<<EOT
Aus dem Buch: ${BUCH}
1 Buch des Geschlechts Jesu Christi, des Sohnes Davids, des Sohnes Abrahams.
2 Abraham zeugte Isaak; Isaak aber zeugte Jakob, Jakob aber zeugte Juda und seine Brüder;
3 Juda aber zeugte Phares und Zara von der Thamar; Phares aber zeugte Esrom, Esrom aber zeugte Aram,
4 Aram aber zeugte Aminadab, Aminadab aber zeugte Nahasson, Nahasson aber zeugte Salmon,
5 Salmon aber zeugte Boas von der Rahab; Boas aber zeugte Obed von der Ruth; Obed aber zeugte Isai,
6 Isai aber zeugte David, den König. David aber zeugte Salomon von der, die Urias Weib gewesen;
EOT
define TEXTNOEXPAND<<"EOT" # or define TEXTNOEXPAND<<'EOT'
Aus dem Buch: ${BUCH}
1 Buch des Geschlechts Jesu Christi, des Sohnes Davids, des Sohnes Abrahams.
2 Abraham zeugte Isaak; Isaak aber zeugte Jakob, Jakob aber zeugte Juda und seine Brüder;
3 Juda aber zeugte Phares und Zara von der Thamar; Phares aber zeugte Esrom, Esrom aber zeugte Aram,
4 Aram aber zeugte Aminadab, Aminadab aber zeugte Nahasson, Nahasson aber zeugte Salmon,
5 Salmon aber zeugte Boas von der Rahab; Boas aber zeugte Obed von der Ruth; Obed aber zeugte Isai,
6 Isai aber zeugte David, den König. David aber zeugte Salomon von der, die Urias Weib gewesen;
EOT
OUTFILE="/tmp/matthäus_eins"
# Create file
>"$OUTFILE"
# Write contents
{
printf "%s\n" "$TEXT"
printf "%s\n" "$TEXTNOEXPAND"
} >>"$OUTFILE"
Пусть Вам ПОВЕЗЕТ!
Есть несколько способов сделать это, позвольте's запускает этот скрипт называется exercise.sh
#!/usr/bin/env bash
> file1.txt cat <<< "This is a here-string with random value $RANDOM"
# Or if you prefer to see what is happening and write to file as well
tee file2.txt <<< "Here is another here-string I can see and write to file"
# if you want to work multiline easily
cat <<EOF > file3.txt
You don't need to escape any quotes here, $ marks start of variables, unless escaped.
This is random value from variable $RANDOM
This is literal \$RANDOM
EOF
# Let's say you have a variable with multiline text and you want to manipulate it
a="
1
2
3
33
"
# Assume I want to have lines containing "3". Instead of grep it can even be another script
a=$(echo "$a" | grep 3)
# Then you want to write this to a file, although here-string is fine,
# if you don't need single-liner command, prefer heredoc
# Herestring. (If it's single liner, variable needs to be quoted to preserve newlines)
> file4.txt cat <<< "$a"
# Heredoc
cat <<EOF > file5.txt
$a
EOF
Это вывод, который вы должны увидеть:
$ bash exercise.sh
Here is another here-string I can see and write to file
И файлы должны содержать данные:
$ ls
exercise.sh file1.txt file2.txt file3.txt file4.txt file5.txt
$ cat file1.txt
This is a here-string with random value 20914
$ cat file2.txt
Here is another here-string I can see and write to file
$ cat file3.txt
You don't need to escape any quotes here, $ marks start of variables, unless escaped.
This is random value from variable 15899
This is literal $RANDOM
$ cat file4.txt
3
33
$ cat file5.txt
3
33