Как считать строки в документе?

У меня есть такие строки, и я хочу знать, сколько строк у меня на самом деле...

09:16:39 AM  all    2.00    0.00    4.00    0.00    0.00    0.00    0.00    0.00   94.00
09:16:40 AM  all    5.00    0.00    0.00    4.00    0.00    0.00    0.00    0.00   91.00
09:16:41 AM  all    0.00    0.00    4.00    0.00    0.00    0.00    0.00    0.00   96.00
09:16:42 AM  all    3.00    0.00    1.00    0.00    0.00    0.00    0.00    0.00   96.00
09:16:43 AM  all    0.00    0.00    1.00    0.00    1.00    0.00    0.00    0.00   98.00
09:16:44 AM  all    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00
09:16:45 AM  all    2.00    0.00    6.00    0.00    0.00    0.00    0.00    0.00   92.00

есть ли способ подсчитать их все с помощью команд linux?

19 ответов


использовать wc:

wc -l <filename>

это выведет количество строк в <filename>:

$ wc -l /dir/file.txt
3272485 /dir/file.txt

или, чтобы пропустить <filename> от результата использования wc -l < <filename>:

$ wc -l < /dir/file.txt
3272485

вы также можете передавать данные в wc а также:

$ cat /dir/file.txt | wc -l
3272485
$ curl yahoo.com --silent | wc -l
63

для подсчета всех строк использовать:

$ wc -l file

для фильтрации и подсчета только строк с использованием шаблона:

$ grep -w "pattern" -c file  

или используйте -v для инвертирования матча:

$ grep -w "pattern" -c -v file 

см. справочную страницу grep, чтобы взглянуть на-e,- i и-x args...


wc -l <file.txt>

или

command | wc -l

есть много способов. используя wc один.

wc -l file

другие включают

awk 'END{print NR}' file

sed -n '$=' file (GNU sed)

grep -c ".*" file

инструмент wc является "счетчиком слов" в UNIX и UNIX-подобных операционных системах, вы также можете использовать его для подсчета строк в файле, добавив , Так что wc -l foo будет подсчитывать количество строк в foo. Вы также можете передать вывод из такой программы:ls -l | wc -l, который скажет вам, сколько файлов в текущем каталоге.


использовать wc:

wc -l <filename>

Если вы хотите проверить общую строку всех файлов в каталоге, вы можете использовать find и wc:

find . -type f -exec wc -l {} +

Если все, что вам нужно, это количество строк (а не количество строк и глупое имя файла):

wc -l < /filepath/filename.ext

Как упоминалось ранее, они также работают (но уступают по другим причинам):

awk 'END{print NR}' file       # not on all unixes
sed -n '$=' file               # (GNU sed) also not on all unixes
grep -c ".*" file              # overkill and probably also slower

использовать nl такой:

nl filename

С man nl:

запишите каждый файл в стандартный вывод с добавлением номеров строк. С нет файла, или когда файл -, прочитайте стандартный ввод.


Я использую этот:

cat myfile.txt | wc -l

Я предпочитаю его принятому ответу, потому что он не печатает имя файла, и вам не нужно использовать awk исправить. Принятый ответ:

wc -l myfile.txt

но я думаю, что лучшим является ответ GGB667:

wc -l < myfile.txt

Я, вероятно, буду использовать это с этого момента. Это немного короче, чем мой способ. Я использую свой старый способ сделать это на случай, если кто-то предпочтет это. Выход такой же с помощью этих двух методов.


выше являются предпочтительным методом, но команда" cat " также может быть полезна:

cat -n <filename>

покажет вам все содержимое файла с номерами строк.


Я видел этот вопрос, когда искал способ подсчета нескольких строк файлов, поэтому, если вы хотите подсчитать несколько строк файла a .txt файл вы можете сделать это,

cat *.txt | wc -l

Он также будет работать на одном .txt файл ;)


wc -l file.txt | cut -f3 -d" "

возвращает только количество строк


cat file.log | wc -l | grep -oE '\d+'
  • grep -oE '\d+': для того, чтобы вернуть цифры только.

Redirection / Piping вывод файла на wc -l должно быть достаточно, например:

cat /etc/fstab | wc -l

который затем предоставит нет. только линий.


Я только что сделал программу для этого (с node )

npm install gimme-lines
gimme-lines verbose --exclude=node_modules,public,vendor --exclude_extensions=html

https://github.com/danschumann/gimme-lines/tree/master


Я знаю, что это старый но все же: количество отфильтрованных строк

мой файл выглядит так:

Number of files sent
Company 1 file: foo.pdf OK
Company 1 file: foo.csv OK
Company 1 file: foo.msg OK
Company 2 file: foo.pdf OK
Company 2 file: foo.csv OK
Company 2 file: foo.msg Error
Company 3 file: foo.pdf OK
Company 3 file: foo.csv OK
Company 3 file: foo.msg Error
Company 4 file: foo.pdf OK
Company 4 file: foo.csv OK
Company 4 file: foo.msg Error

Если я хочу знать, сколько файлов отправляется OK:

grep "OK" <filename> | wc -l

или

grep -c "OK" filename

как wc -l является лучшим решением, но для дальнейшего использования вы можете использовать Perl:

perl -lne 'END { print $. }'

$. содержит номер строки и END блок будет выполняться в конце сценария.


или подсчитайте все строки в подкаталогах с шаблоном имени файла (например, файлы журналов с метками времени в имени файла):

wc -l ./**/*_SuccessLog.csv