Как сохранить вывод из команды (например, diff) в переменную

Если вам требуется только общее разрешение на установку / запрет на установку пакета, перейдите в PolicyKit.

К сожалению, PolicyKit не имеет точного контроля над установленным пакетом. Если вы хотите дать своим пользователям разрешение на установку только ограниченного набора приложений, вы должны использовать sudo и установить что-то вроде программных каналов ...

Я также искал что-то подобное, но так как я сделал «Я ничего не нашел, я закодировал это« программные каналы »для простого решения», доступный здесь, в GitHub

. Это очень простая система, позволяющая обычным (не административным) пользователям устанавливать пакеты из ограниченных каталогов. [!d4 ]

Просто определите «каналы» (группы пакетов) в простом текстовом файле и дайте вашим пользователям разрешения запуска программных каналов.

Они будут видеть пакеты только в каналах, соответствующих их группам unix.

]
21
задан 13 August 2011 в 18:07

32 ответа

Это работает:

if diff "./helloworld$x.out" "./output/helloworld$x.out" >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi

Если вы используете переменную вместо echo, вы можете удалить ветвь else: установите переменную в false до if и сохраните 2 строки Код.

Если вы хотите на самом деле поместить результат в переменную, используйте:

some_var="$(diff "./helloworld$x.out" "./output/helloworld$x.out")"

Включая мой тест, чтобы увидеть, действительно ли он работает:

rinzwind@discworld:~$ touch 1 rinzwind@discworld:~$ touch 2 rinzwind@discworld:~$ more test if diff 1 2 >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi rinzwind@discworld:~$ ./test Passed rinzwind@discworld:~$ vi 2 rinzwind@discworld:~$ more 2 2 rinzwind@discworld:~$ ./test Failed

На части >/dev/null: >/dev/null 2>&1 отправит вывод на >/dev/null, а 2>&1 отправит стандартные ошибки в один и тот же файл (&1 означает «использовать первый параметр») перед этой командой (так он также использует /dev/null).

sidenote: sdiff будет показывать бок о бок diff:

sdiff 1 2 1 1 2 2 3 3 4 4 5 5 7 7 > 8 9 9 10 10
18
ответ дан 25 May 2018 в 19:21
  • 1
    Спасибо, что это работает, но я не понимаю, что делает ... > /dev/null в этом контексте. Вывод diff будет goto / dev / null, но разве это не так? – Jiew Meng 13 August 2011 в 18:48
  • 2
    Функция diff выдаст все различия между файлами на вашем экране и & gt; / dev / null гарантирует, что вывод команды будет перенаправлен в забвение. Значение if все равно выполняется на основе результата. – Rinzwind 13 August 2011 в 18:51
  • 3
    Оператор if проверяет код выхода команды diff. 0 означает, что никаких различий не обнаружено, а 1 означает наличие одного или нескольких различий. – Knut Eldhuset 15 May 2012 в 12:38

Это работает:

if diff "./helloworld$x.out" "./output/helloworld$x.out" >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi

Если вы используете переменную вместо echo, вы можете удалить ветвь else: установите переменную в false до if и сохраните 2 строки Код.

Если вы хотите на самом деле поместить результат в переменную, используйте:

some_var="$(diff "./helloworld$x.out" "./output/helloworld$x.out")"

Включая мой тест, чтобы увидеть, действительно ли он работает:

rinzwind@discworld:~$ touch 1 rinzwind@discworld:~$ touch 2 rinzwind@discworld:~$ more test if diff 1 2 >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi rinzwind@discworld:~$ ./test Passed rinzwind@discworld:~$ vi 2 rinzwind@discworld:~$ more 2 2 rinzwind@discworld:~$ ./test Failed

На части >/dev/null: >/dev/null 2>&1 отправит вывод на >/dev/null, а 2>&1 отправит стандартные ошибки в один и тот же файл (&1 означает «использовать первый параметр») перед этой командой (так он также использует /dev/null).

sidenote: sdiff будет показывать бок о бок diff:

sdiff 1 2 1 1 2 2 3 3 4 4 5 5 7 7 > 8 9 9 10 10
18
ответ дан 25 July 2018 в 21:28

Это работает:

if diff "./helloworld$x.out" "./output/helloworld$x.out" >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi

Если вы используете переменную вместо echo, вы можете удалить ветвь else: установите переменную в false до if и сохраните 2 строки Код.

Если вы хотите на самом деле поместить результат в переменную, используйте:

some_var="$(diff "./helloworld$x.out" "./output/helloworld$x.out")"

Включая мой тест, чтобы увидеть, действительно ли он работает:

rinzwind@discworld:~$ touch 1 rinzwind@discworld:~$ touch 2 rinzwind@discworld:~$ more test if diff 1 2 >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi rinzwind@discworld:~$ ./test Passed rinzwind@discworld:~$ vi 2 rinzwind@discworld:~$ more 2 2 rinzwind@discworld:~$ ./test Failed

На части >/dev/null: >/dev/null 2>&1 отправит вывод на >/dev/null, а 2>&1 отправит стандартные ошибки в один и тот же файл (&1 означает «использовать первый параметр») перед этой командой (так он также использует /dev/null).

sidenote: sdiff будет показывать бок о бок diff:

sdiff 1 2 1 1 2 2 3 3 4 4 5 5 7 7 > 8 9 9 10 10
18
ответ дан 31 July 2018 в 10:34

Это работает:

if diff "./helloworld$x.out" "./output/helloworld$x.out" >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi

Если вы используете переменную вместо echo, вы можете удалить ветвь else: установите переменную в false до if и сохраните 2 строки Код.

Если вы хотите на самом деле поместить результат в переменную, используйте:

some_var="$(diff "./helloworld$x.out" "./output/helloworld$x.out")"

Включая мой тест, чтобы увидеть, действительно ли он работает:

rinzwind@discworld:~$ touch 1 rinzwind@discworld:~$ touch 2 rinzwind@discworld:~$ more test if diff 1 2 >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi rinzwind@discworld:~$ ./test Passed rinzwind@discworld:~$ vi 2 rinzwind@discworld:~$ more 2 2 rinzwind@discworld:~$ ./test Failed

На части >/dev/null: >/dev/null 2>&1 отправит вывод на >/dev/null, а 2>&1 отправит стандартные ошибки в один и тот же файл (&1 означает «использовать первый параметр») перед этой командой (так он также использует /dev/null).

sidenote: sdiff будет показывать бок о бок diff:

sdiff 1 2 1 1 2 2 3 3 4 4 5 5 7 7 > 8 9 9 10 10
18
ответ дан 31 July 2018 в 11:37

Это работает:

if diff "./helloworld$x.out" "./output/helloworld$x.out" >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi

Если вы используете переменную вместо echo, вы можете удалить ветвь else: установите переменную в false до if и сохраните 2 строки Код.

Если вы хотите на самом деле поместить результат в переменную, используйте:

some_var="$(diff "./helloworld$x.out" "./output/helloworld$x.out")"

Включая мой тест, чтобы увидеть, действительно ли он работает:

rinzwind@discworld:~$ touch 1 rinzwind@discworld:~$ touch 2 rinzwind@discworld:~$ more test if diff 1 2 >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi rinzwind@discworld:~$ ./test Passed rinzwind@discworld:~$ vi 2 rinzwind@discworld:~$ more 2 2 rinzwind@discworld:~$ ./test Failed

На части >/dev/null: >/dev/null 2>&1 отправит вывод на >/dev/null, а 2>&1 отправит стандартные ошибки в один и тот же файл (&1 означает «использовать первый параметр») перед этой командой (так он также использует /dev/null).

sidenote: sdiff будет показывать бок о бок diff:

sdiff 1 2 1 1 2 2 3 3 4 4 5 5 7 7 > 8 9 9 10 10
18
ответ дан 2 August 2018 в 03:06

Это работает:

if diff "./helloworld$x.out" "./output/helloworld$x.out" >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi

Если вы используете переменную вместо echo, вы можете удалить ветвь else: установите переменную в false до if и сохраните 2 строки Код.

Если вы хотите на самом деле поместить результат в переменную, используйте:

some_var="$(diff "./helloworld$x.out" "./output/helloworld$x.out")"

Включая мой тест, чтобы увидеть, действительно ли он работает:

rinzwind@discworld:~$ touch 1 rinzwind@discworld:~$ touch 2 rinzwind@discworld:~$ more test if diff 1 2 >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi rinzwind@discworld:~$ ./test Passed rinzwind@discworld:~$ vi 2 rinzwind@discworld:~$ more 2 2 rinzwind@discworld:~$ ./test Failed

На части >/dev/null: >/dev/null 2>&1 отправит вывод на >/dev/null, а 2>&1 отправит стандартные ошибки в один и тот же файл (&1 означает «использовать первый параметр») перед этой командой (так он также использует /dev/null).

sidenote: sdiff будет показывать бок о бок diff:

sdiff 1 2 1 1 2 2 3 3 4 4 5 5 7 7 > 8 9 9 10 10
18
ответ дан 4 August 2018 в 18:57

Это работает:

if diff "./helloworld$x.out" "./output/helloworld$x.out" >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi

Если вы используете переменную вместо echo, вы можете удалить ветвь else: установите переменную в false до if и сохраните 2 строки Код.

Если вы хотите на самом деле поместить результат в переменную, используйте:

some_var="$(diff "./helloworld$x.out" "./output/helloworld$x.out")"

Включая мой тест, чтобы увидеть, действительно ли он работает:

rinzwind@discworld:~$ touch 1 rinzwind@discworld:~$ touch 2 rinzwind@discworld:~$ more test if diff 1 2 >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi rinzwind@discworld:~$ ./test Passed rinzwind@discworld:~$ vi 2 rinzwind@discworld:~$ more 2 2 rinzwind@discworld:~$ ./test Failed

На части >/dev/null: >/dev/null 2>&1 отправит вывод на >/dev/null, а 2>&1 отправит стандартные ошибки в один и тот же файл (&1 означает «использовать первый параметр») перед этой командой (так он также использует /dev/null).

sidenote: sdiff будет показывать бок о бок diff:

sdiff 1 2 1 1 2 2 3 3 4 4 5 5 7 7 > 8 9 9 10 10
18
ответ дан 6 August 2018 в 03:19

Это работает:

if diff "./helloworld$x.out" "./output/helloworld$x.out" >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi

Если вы используете переменную вместо echo, вы можете удалить ветвь else: установите переменную в false до if и сохраните 2 строки Код.

Если вы хотите на самом деле поместить результат в переменную, используйте:

some_var="$(diff "./helloworld$x.out" "./output/helloworld$x.out")"

Включая мой тест, чтобы увидеть, действительно ли он работает:

rinzwind@discworld:~$ touch 1 rinzwind@discworld:~$ touch 2 rinzwind@discworld:~$ more test if diff 1 2 >/dev/null; then echo "Passed $x"; else echo "Failed $x"; fi rinzwind@discworld:~$ ./test Passed rinzwind@discworld:~$ vi 2 rinzwind@discworld:~$ more 2 2 rinzwind@discworld:~$ ./test Failed

На части >/dev/null: >/dev/null 2>&1 отправит вывод на >/dev/null, а 2>&1 отправит стандартные ошибки в один и тот же файл (&1 означает «использовать первый параметр») перед этой командой (так он также использует /dev/null).

sidenote: sdiff будет показывать бок о бок diff:

sdiff 1 2 1 1 2 2 3 3 4 4 5 5 7 7 > 8 9 9 10 10
18
ответ дан 7 August 2018 в 21:00

diff может даже полностью отключить вывод, за исключением сообщения «Файлы / bin / bash и / bin / sh differ» с использованием кода ниже.

file1="./helloworld$x.out"
file2="./output/helloworld$x.out"

if diff -q "$file1" "$file2"; then
    echo "Passed $x"
else
    echo "Failed $x"
fi

Если вы даже хотите скрыть это сообщение, вы должны добавить > /dev/null после команды diff, чтобы скрыть вывод diff:

if diff -q "$file1" "$file2" >/dev/null; then

/dev/null - это специальный файл, который действует как черная дыра, если вы пишете

Обратите внимание, что bash не нуждается в ; для завершения строк.

Что касается исходного вопроса, чтобы сохранить вывод программы в переменной:

file1="./helloworld$x.out"
file2="./output/helloworld$x.out"
output="$(diff -q "$file1" "$file2")"

# the quotes are mandatory, this checks whether $output is empty or not
if [ -n "$output" ]; then
    echo "Passed $x"
else
    echo "Failed $x"
fi

Альтернативные способы проверки, является ли переменная пустой:

[ "$output" = "" ]
[ "$output" == "" ]
[[ "$output" == "" ]]
[[ $output == "" ]]

re, используя Bash, последние две команды рекомендуются для сравнения строк. В противном случае рекомендуется использовать первый и [ -n "$output" ].

17
ответ дан 25 May 2018 в 19:21

a) Вывод команды 1 может быть задан с помощью

output=$(diff "helloworld$x.out" "output/helloworld$x.out") 

или с обратными окнами, но это не рекомендуется, потому что вы не можете их вложить, и их может быть трудно отличить от апострофов, в зависимости от шрифта:

 output=`cmd1`

b) Вместо того, чтобы записывать в файл, а затем читать этот файл (или захватывать вывод, а затем эхом его), вы должны использовать прямой канал:

 cmd1 > file
 cat file | cmd2 

 output=$(cmd1)
 echo "${output}" | cmd2 

=>

 cmd1 | cmd2 

, но в вашем примере вы не заинтересованы в выходе, но результат программы - это сработало?

 diff "helloworld$x.out" "output/helloworld$x.out" && echo "success" || echo "failure" 

Чтобы прочитать об использовании & amp; & amp; и || найдите «ярлык AND и ярлык OR».

Чтобы сохранить вывод чистым, вы можете перенаправить вывод «diff» в никуда:

 diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null && echo "success" || echo "failure" 

Чтобы получить успех и оценить это позже, вы сохраняете результат последней команды в переменной с $ ?:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null
result=$?
# do something else
case $result in 
   0) echo success ;;
   *) echo failure ;;
esac
6
ответ дан 25 May 2018 в 19:21

Если вы хотите знать, являются ли два файла одинаковыми или отличаются (но не важно, какая разница на самом деле), cmp более подходит.

if cmp -s file1 file2; then echo "Equal"; else echo "Not equal"; fi
3
ответ дан 25 May 2018 в 19:21

Если вы хотите знать, являются ли два файла одинаковыми или отличаются (но не важно, какая разница на самом деле), cmp более подходит.

if cmp -s file1 file2; then echo "Equal"; else echo "Not equal"; fi
3
ответ дан 25 July 2018 в 21:28

a) Вывод команды 1 может быть задан с помощью

output=$(diff "helloworld$x.out" "output/helloworld$x.out")

или с обратными окнами, но это не рекомендуется, потому что вы не можете их вложить, и их может быть трудно отличить от апострофов, в зависимости от шрифта:

output=`cmd1`

b) Вместо того, чтобы записывать в файл, а затем читать этот файл (или захватывать вывод, а затем эхом его), вы должны использовать прямой канал:

cmd1 > file cat file | cmd2 output=$(cmd1) echo "${output}" | cmd2

=>

cmd1 | cmd2

, но в вашем примере вы не заинтересованы в выходе, но результат программы - это сработало?

diff "helloworld$x.out" "output/helloworld$x.out" && echo "success" || echo "failure"

Чтобы прочитать об использовании & amp; & amp; и || найдите «ярлык AND и ярлык OR».

Чтобы сохранить вывод чистым, вы можете перенаправить вывод «diff» в никуда:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null && echo "success" || echo "failure"

Чтобы получить успех и оценить это позже, вы сохраняете результат последней команды в переменной с $ ?:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null result=$? # do something else case $result in 0) echo success ;; *) echo failure ;; esac
6
ответ дан 25 July 2018 в 21:28

diff может даже полностью отключить вывод, за исключением сообщения «Файлы / bin / bash и / bin / sh differ» с использованием кода ниже.

file1="./helloworld$x.out" file2="./output/helloworld$x.out" if diff -q "$file1" "$file2"; then echo "Passed $x" else echo "Failed $x" fi

Если вы даже хотите скрыть это сообщение, вы должны добавить > /dev/null после команды diff, чтобы скрыть вывод diff:

if diff -q "$file1" "$file2" >/dev/null; then

/dev/null - это специальный файл, который действует как черная дыра, если вы пишете

Обратите внимание, что bash не нуждается в ; для завершения строк.

Что касается исходного вопроса, чтобы сохранить вывод программы в переменной:

file1="./helloworld$x.out" file2="./output/helloworld$x.out" output="$(diff -q "$file1" "$file2")" # the quotes are mandatory, this checks whether $output is empty or not if [ -n "$output" ]; then echo "Passed $x" else echo "Failed $x" fi

Альтернативные способы проверки, является ли переменная пустой:

[ "$output" = "" ] [ "$output" == "" ] [[ "$output" == "" ]] [[ $output == "" ]]

re, используя Bash, последние две команды рекомендуются для сравнения строк. В противном случае рекомендуется использовать первый и [ -n "$output" ].

17
ответ дан 25 July 2018 в 21:28

Если вы хотите знать, являются ли два файла одинаковыми или отличаются (но не важно, какая разница на самом деле), cmp более подходит.

if cmp -s file1 file2; then echo "Equal"; else echo "Not equal"; fi
3
ответ дан 31 July 2018 в 10:34

a) Вывод команды 1 может быть задан с помощью

output=$(diff "helloworld$x.out" "output/helloworld$x.out")

или с обратными окнами, но это не рекомендуется, потому что вы не можете их вложить, и их может быть трудно отличить от апострофов, в зависимости от шрифта:

output=`cmd1`

b) Вместо того, чтобы записывать в файл, а затем читать этот файл (или захватывать вывод, а затем эхом его), вы должны использовать прямой канал:

cmd1 > file cat file | cmd2 output=$(cmd1) echo "${output}" | cmd2

=>

cmd1 | cmd2

, но в вашем примере вы не заинтересованы в выходе, но результат программы - это сработало?

diff "helloworld$x.out" "output/helloworld$x.out" && echo "success" || echo "failure"

Чтобы прочитать об использовании & amp; & amp; и || найдите «ярлык AND и ярлык OR».

Чтобы сохранить вывод чистым, вы можете перенаправить вывод «diff» в никуда:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null && echo "success" || echo "failure"

Чтобы получить успех и оценить это позже, вы сохраняете результат последней команды в переменной с $ ?:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null result=$? # do something else case $result in 0) echo success ;; *) echo failure ;; esac
6
ответ дан 31 July 2018 в 10:34

diff может даже полностью отключить вывод, за исключением сообщения «Файлы / bin / bash и / bin / sh differ» с использованием кода ниже.

file1="./helloworld$x.out" file2="./output/helloworld$x.out" if diff -q "$file1" "$file2"; then echo "Passed $x" else echo "Failed $x" fi

Если вы даже хотите скрыть это сообщение, вы должны добавить > /dev/null после команды diff, чтобы скрыть вывод diff:

if diff -q "$file1" "$file2" >/dev/null; then

/dev/null - это специальный файл, который действует как черная дыра, если вы пишете

Обратите внимание, что bash не нуждается в ; для завершения строк.

Что касается исходного вопроса, чтобы сохранить вывод программы в переменной:

file1="./helloworld$x.out" file2="./output/helloworld$x.out" output="$(diff -q "$file1" "$file2")" # the quotes are mandatory, this checks whether $output is empty or not if [ -n "$output" ]; then echo "Passed $x" else echo "Failed $x" fi

Альтернативные способы проверки, является ли переменная пустой:

[ "$output" = "" ] [ "$output" == "" ] [[ "$output" == "" ]] [[ $output == "" ]]

re, используя Bash, последние две команды рекомендуются для сравнения строк. В противном случае рекомендуется использовать первый и [ -n "$output" ].

17
ответ дан 31 July 2018 в 10:34

Если вы хотите знать, являются ли два файла одинаковыми или отличаются (но не важно, какая разница на самом деле), cmp более подходит.

if cmp -s file1 file2; then echo "Equal"; else echo "Not equal"; fi
3
ответ дан 31 July 2018 в 11:37

a) Вывод команды 1 может быть задан с помощью

output=$(diff "helloworld$x.out" "output/helloworld$x.out")

или с обратными окнами, но это не рекомендуется, потому что вы не можете их вложить, и их может быть трудно отличить от апострофов, в зависимости от шрифта:

output=`cmd1`

b) Вместо того, чтобы записывать в файл, а затем читать этот файл (или захватывать вывод, а затем эхом его), вы должны использовать прямой канал:

cmd1 > file cat file | cmd2 output=$(cmd1) echo "${output}" | cmd2

=>

cmd1 | cmd2

, но в вашем примере вы не заинтересованы в выходе, но результат программы - это сработало?

diff "helloworld$x.out" "output/helloworld$x.out" && echo "success" || echo "failure"

Чтобы прочитать об использовании & amp; & amp; и || найдите «ярлык AND и ярлык OR».

Чтобы сохранить вывод чистым, вы можете перенаправить вывод «diff» в никуда:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null && echo "success" || echo "failure"

Чтобы получить успех и оценить это позже, вы сохраняете результат последней команды в переменной с $ ?:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null result=$? # do something else case $result in 0) echo success ;; *) echo failure ;; esac
6
ответ дан 31 July 2018 в 11:37

diff может даже полностью отключить вывод, за исключением сообщения «Файлы / bin / bash и / bin / sh differ» с использованием кода ниже.

file1="./helloworld$x.out" file2="./output/helloworld$x.out" if diff -q "$file1" "$file2"; then echo "Passed $x" else echo "Failed $x" fi

Если вы даже хотите скрыть это сообщение, вы должны добавить > /dev/null после команды diff, чтобы скрыть вывод diff:

if diff -q "$file1" "$file2" >/dev/null; then

/dev/null - это специальный файл, который действует как черная дыра, если вы пишете

Обратите внимание, что bash не нуждается в ; для завершения строк.

Что касается исходного вопроса, чтобы сохранить вывод программы в переменной:

file1="./helloworld$x.out" file2="./output/helloworld$x.out" output="$(diff -q "$file1" "$file2")" # the quotes are mandatory, this checks whether $output is empty or not if [ -n "$output" ]; then echo "Passed $x" else echo "Failed $x" fi

Альтернативные способы проверки, является ли переменная пустой:

[ "$output" = "" ] [ "$output" == "" ] [[ "$output" == "" ]] [[ $output == "" ]]

re, используя Bash, последние две команды рекомендуются для сравнения строк. В противном случае рекомендуется использовать первый и [ -n "$output" ].

17
ответ дан 31 July 2018 в 11:37

Если вы хотите знать, являются ли два файла одинаковыми или отличаются (но не важно, какая разница на самом деле), cmp более подходит.

if cmp -s file1 file2; then echo "Equal"; else echo "Not equal"; fi
3
ответ дан 2 August 2018 в 03:06

a) Вывод команды 1 может быть задан с помощью

output=$(diff "helloworld$x.out" "output/helloworld$x.out")

или с обратными окнами, но это не рекомендуется, потому что вы не можете их вложить, и их может быть трудно отличить от апострофов, в зависимости от шрифта:

output=`cmd1`

b) Вместо того, чтобы записывать в файл, а затем читать этот файл (или захватывать вывод, а затем эхом его), вы должны использовать прямой канал:

cmd1 > file cat file | cmd2 output=$(cmd1) echo "${output}" | cmd2

=>

cmd1 | cmd2

, но в вашем примере вы не заинтересованы в выходе, но результат программы - это сработало?

diff "helloworld$x.out" "output/helloworld$x.out" && echo "success" || echo "failure"

Чтобы прочитать об использовании & amp; & amp; и || найдите «ярлык AND и ярлык OR».

Чтобы сохранить вывод чистым, вы можете перенаправить вывод «diff» в никуда:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null && echo "success" || echo "failure"

Чтобы получить успех и оценить это позже, вы сохраняете результат последней команды в переменной с $ ?:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null result=$? # do something else case $result in 0) echo success ;; *) echo failure ;; esac
6
ответ дан 2 August 2018 в 03:06

diff может даже полностью отключить вывод, за исключением сообщения «Файлы / bin / bash и / bin / sh differ» с использованием кода ниже.

file1="./helloworld$x.out" file2="./output/helloworld$x.out" if diff -q "$file1" "$file2"; then echo "Passed $x" else echo "Failed $x" fi

Если вы даже хотите скрыть это сообщение, вы должны добавить > /dev/null после команды diff, чтобы скрыть вывод diff:

if diff -q "$file1" "$file2" >/dev/null; then

/dev/null - это специальный файл, который действует как черная дыра, если вы пишете

Обратите внимание, что bash не нуждается в ; для завершения строк.

Что касается исходного вопроса, чтобы сохранить вывод программы в переменной:

file1="./helloworld$x.out" file2="./output/helloworld$x.out" output="$(diff -q "$file1" "$file2")" # the quotes are mandatory, this checks whether $output is empty or not if [ -n "$output" ]; then echo "Passed $x" else echo "Failed $x" fi

Альтернативные способы проверки, является ли переменная пустой:

[ "$output" = "" ] [ "$output" == "" ] [[ "$output" == "" ]] [[ $output == "" ]]

re, используя Bash, последние две команды рекомендуются для сравнения строк. В противном случае рекомендуется использовать первый и [ -n "$output" ].

17
ответ дан 2 August 2018 в 03:06

Если вы хотите знать, являются ли два файла одинаковыми или отличаются (но не важно, какая разница на самом деле), cmp более подходит.

if cmp -s file1 file2; then echo "Equal"; else echo "Not equal"; fi
3
ответ дан 4 August 2018 в 18:57

a) Вывод команды 1 может быть задан с помощью

output=$(diff "helloworld$x.out" "output/helloworld$x.out")

или с обратными окнами, но это не рекомендуется, потому что вы не можете их вложить, и их может быть трудно отличить от апострофов, в зависимости от шрифта:

output=`cmd1`

b) Вместо того, чтобы записывать в файл, а затем читать этот файл (или захватывать вывод, а затем эхом его), вы должны использовать прямой канал:

cmd1 > file cat file | cmd2 output=$(cmd1) echo "${output}" | cmd2

=>

cmd1 | cmd2

, но в вашем примере вы не заинтересованы в выходе, но результат программы - это сработало?

diff "helloworld$x.out" "output/helloworld$x.out" && echo "success" || echo "failure"

Чтобы прочитать об использовании & amp; & amp; и || найдите «ярлык AND и ярлык OR».

Чтобы сохранить вывод чистым, вы можете перенаправить вывод «diff» в никуда:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null && echo "success" || echo "failure"

Чтобы получить успех и оценить это позже, вы сохраняете результат последней команды в переменной с $ ?:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null result=$? # do something else case $result in 0) echo success ;; *) echo failure ;; esac
6
ответ дан 4 August 2018 в 18:57

diff может даже полностью отключить вывод, за исключением сообщения «Файлы / bin / bash и / bin / sh differ» с использованием кода ниже.

file1="./helloworld$x.out" file2="./output/helloworld$x.out" if diff -q "$file1" "$file2"; then echo "Passed $x" else echo "Failed $x" fi

Если вы даже хотите скрыть это сообщение, вы должны добавить > /dev/null после команды diff, чтобы скрыть вывод diff:

if diff -q "$file1" "$file2" >/dev/null; then

/dev/null - это специальный файл, который действует как черная дыра, если вы пишете

Обратите внимание, что bash не нуждается в ; для завершения строк.

Что касается исходного вопроса, чтобы сохранить вывод программы в переменной:

file1="./helloworld$x.out" file2="./output/helloworld$x.out" output="$(diff -q "$file1" "$file2")" # the quotes are mandatory, this checks whether $output is empty or not if [ -n "$output" ]; then echo "Passed $x" else echo "Failed $x" fi

Альтернативные способы проверки, является ли переменная пустой:

[ "$output" = "" ] [ "$output" == "" ] [[ "$output" == "" ]] [[ $output == "" ]]

re, используя Bash, последние две команды рекомендуются для сравнения строк. В противном случае рекомендуется использовать первый и [ -n "$output" ].

17
ответ дан 4 August 2018 в 18:57

Если вы хотите знать, являются ли два файла одинаковыми или отличаются (но не важно, какая разница на самом деле), cmp более подходит.

if cmp -s file1 file2; then echo "Equal"; else echo "Not equal"; fi
3
ответ дан 6 August 2018 в 03:19

a) Вывод команды 1 может быть задан с помощью

output=$(diff "helloworld$x.out" "output/helloworld$x.out")

или с обратными окнами, но это не рекомендуется, потому что вы не можете их вложить, и их может быть трудно отличить от апострофов, в зависимости от шрифта:

output=`cmd1`

b) Вместо того, чтобы записывать в файл, а затем читать этот файл (или захватывать вывод, а затем эхом его), вы должны использовать прямой канал:

cmd1 > file cat file | cmd2 output=$(cmd1) echo "${output}" | cmd2

=>

cmd1 | cmd2

, но в вашем примере вы не заинтересованы в выходе, но результат программы - это сработало?

diff "helloworld$x.out" "output/helloworld$x.out" && echo "success" || echo "failure"

Чтобы прочитать об использовании & amp; & amp; и || найдите «ярлык AND и ярлык OR».

Чтобы сохранить вывод чистым, вы можете перенаправить вывод «diff» в никуда:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null && echo "success" || echo "failure"

Чтобы получить успех и оценить это позже, вы сохраняете результат последней команды в переменной с $ ?:

diff "helloworld$x.out" "output/helloworld$x.out" >/dev/null result=$? # do something else case $result in 0) echo success ;; *) echo failure ;; esac
6
ответ дан 6 August 2018 в 03:19

diff может даже полностью отключить вывод, за исключением сообщения «Файлы / bin / bash и / bin / sh differ» с использованием кода ниже.

file1="./helloworld$x.out" file2="./output/helloworld$x.out" if diff -q "$file1" "$file2"; then echo "Passed $x" else echo "Failed $x" fi

Если вы даже хотите скрыть это сообщение, вы должны добавить > /dev/null после команды diff, чтобы скрыть вывод diff:

if diff -q "$file1" "$file2" >/dev/null; then

/dev/null - это специальный файл, который действует как черная дыра, если вы пишете

Обратите внимание, что bash не нуждается в ; для завершения строк.

Что касается исходного вопроса, чтобы сохранить вывод программы в переменной:

file1="./helloworld$x.out" file2="./output/helloworld$x.out" output="$(diff -q "$file1" "$file2")" # the quotes are mandatory, this checks whether $output is empty or not if [ -n "$output" ]; then echo "Passed $x" else echo "Failed $x" fi

Альтернативные способы проверки, является ли переменная пустой:

[ "$output" = "" ] [ "$output" == "" ] [[ "$output" == "" ]] [[ $output == "" ]]

re, используя Bash, последние две команды рекомендуются для сравнения строк. В противном случае рекомендуется использовать первый и [ -n "$output" ].

17
ответ дан 6 August 2018 в 03:19

Если вы хотите знать, являются ли два файла одинаковыми или отличаются (но не важно, какая разница на самом деле), cmp более подходит.

if cmp -s file1 file2; then echo "Equal"; else echo "Not equal"; fi
3
ответ дан 7 August 2018 в 21:00

Другие вопросы по тегам:

Похожие вопросы: