-Gt продолжит числовое сравнение, а не ASCII.

я есть два файла:
f1.txt:

1

Dest / f1.txt:

1
2

Когда я бегуwc -l на обоих этих файлах в терминале Linux - я получаю ожидаемые результаты:

$ wc -l < f1.txt
$ 1
$ wc -l < dest/f1.txt
$ 2

Но когда я запускаю следующий файл .sh:

#!/bin/bash

    if [ $(wc -l < f1.txt) > $(wc -l < dest/f1.txt) ]; then
        echo -e "f1 has more lines"
    else
        echo -e "f1 doesn't have more lines"
    fi

Выход:

f1 has more lines            

Можете ли вы объяснить, как это возможно?

 chepner14 дек. 2017 г., 13:53
Обратите внимание, что если высделал хочу использовать> (для сравнения строк), вам нужно экранировать его, чтобы он не рассматривался как оператор перенаправления, так как[ это обычная команда, а не специальный синтаксис. У вас должен быть новый файл с числовым именем в вашем каталоге.
 dimo41414 дек. 2017 г., 10:33
использование(( ... )) вместо[ ... ] для арифметики.
 anubhava14 дек. 2017 г., 09:41
использование-gt вместо>

Ответы на вопрос(3)

[ также команда в Bash так[ 1 > 2 ] такой же как[ 1 ] > 2 который преуспеет и создаст файл с именем2.

Как отмечали другие, вам нужно использовать следующий синтаксис для сравнения целых чисел:

[ 1 -gt 2 ]
[[ 1 -gt 2 ]]
(( 1 > 2 ))
 Yoory N.14 дек. 2017 г., 10:45
Черт,[ 1 > 2 ] действительно создает файл с именем2! Теперь у меня есть еще одна причина не использовать одну скобку[ оператор. Спасибо :)
Решение Вопроса

-gt зацелочисленное сравнение вif пункт.

Если вы используете> или же< в конечном итоге вы будете делатьASCII алфавитный порядок сравнения.

целочисленное сравнение

-eq равно

if [ "$a" -eq "$b" ]

-ne не равно

if [ "$a" -ne "$b" ]

-gt больше, чем

if [ "$a" -gt "$b" ]

-ge Больше или равно

if [ "$a" -ge "$b" ]

-lt меньше чем

if [ "$a" -lt "$b" ]

-le меньше или равно

if [ "$a" -le "$b" ]

< меньше чем (в двойных скобках)

(("$a" < "$b"))

<= меньше или равно (в двойных скобках)

(("$a" <= "$b"))

> больше, чем (в двойных скобках)

(("$a" > "$b"))

>= Больше или равно (в двойных скобках)

(("$a" >= "$b"))

сравнение строк

= равно

if [ "$a" = "$b" ]

предосторожность
Обратите внимание на пробелы, обрамляющие=.

if [ "$a"="$b" ] is not equivalent to the above.

== равно

if [ "$a" == "$b" ]

Это синоним=.

Note    
The == comparison operator behaves differently within a double-brackets test than within single brackets.
[[ $a == z* ]]   # True if $a starts with an "z" (pattern matching).
[[ $a == "z*" ]] # True if $a is equal to z* (literal matching).

[ $a == z* ]     # File globbing and word splitting take place.
[ "$a" == "z*" ] # True if $a is equal to z* (literal matching).

!= не равно

if [ "$a" != "$b" ]

Этот оператор использует сопоставление с образцом внутри[[ ... ]] построить.

< меньше, в алфавитном порядке ASCII

if [[ "$a" < "$b" ]]

if [ "$a" \< "$b" ]

Обратите внимание, что"<" необходимо избежать в течение[ ] построить.

> больше, чем в алфавитном порядке ASCII

if [[ "$a" > "$b" ]]

if [ "$a" \> "$b" ]

Note that the ">" needs to be escaped within a [ ] construct.

-z строка равна нулю, то есть имеет нулевую длину

String=''   # Zero-length ("null") string variable.

if [ -z "$String" ]
then
  echo "\$String is null."
else
  echo "\$String is NOT null."
fi     # $String is null.

-n
string is not null.

Источник:http://tldp.org/LDP/abs/html/comparison-ops.html

Попробуйте с этим кодом:

#!/bin/bash

if [ $(wc -l < f1.txt) -gt $(wc -l < dest/f1.txt) ]; then
    echo -e "f1 has more lines"
else
    echo -e "f1 doesn't have more lines"
fi

-Gt продолжит числовое сравнение, а не ASCII.

Ваш ответ на вопрос