'grep'명령은 무엇을합니까?


15

터미널을 더 많이 사용할 수 있도록 사용법을 배우고 싶습니다.


3
시스템 유틸리티에 대해 알아내는 첫 번째 단계는 매뉴얼 페이지를 확인하는 것입니다 (예 :) man grep.
Glutanimate

답변:


10

grep파일 또는 다른 명령의 출력에서 ​​텍스트를 검색하는 데 사용됩니다. 일치하는 줄이나 일치하지 않는 줄을 반환 할 수 있습니다.


6

이름

   grep, egrep, fgrep - print lines matching a pattern

개요

   grep [options] PATTERN [FILE...]
   grep [options] [-e PATTERN | -f FILE] [FILE...]

기술

   Grep  searches the named input FILEs (or standard input if no files are
   named, or the file name - is given) for lines containing a match to the
   given PATTERN.  By default, grep prints the matching lines.

   In addition, two variant programs egrep and fgrep are available.  Egrep
   is the same as grep -E.  Fgrep is the same as grep -F.

옵션

   -A NUM, --after-context=NUM
      Print NUM  lines  of  trailing  context  after  matching  lines.
      Places  a  line  containing  --  between  contiguous  groups  of
      matches.

   -a, --text
      Process a binary file as if it were text; this is equivalent  to
      the --binary-files=text option.

   -B NUM, --before-context=NUM
      Print  NUM  lines  of  leading  context  before  matching lines.
      Places  a  line  containing  --  between  contiguous  groups  of
      matches.

   -C NUM, --context=NUM
      Print  NUM lines of output context.  Places a line containing --
      between contiguous groups of matches.

   -b, --byte-offset
      Print the byte offset within the input file before each line  of
      output.

   --binary-files=TYPE
      If the first few bytes of a file indicate that the file contains
      binary data, assume that the file is of type TYPE.  By  default,
      TYPE is binary, and grep normally outputs either a one-line mes-
      sage saying that a binary file matches, or no message  if  there
      is  no  match.   If  TYPE  is without-match, grep assumes that a
      binary file does not match; this is equivalent to the -I option.
      If  TYPE  is  text,  grep  processes a binary file as if it were
      text; this is  equivalent  to  the  -a  option.   Warning:  grep
      --binary-files=text  might output binary garbage, which can have
      nasty side effects if the output is a terminal and if the termi-
      nal driver interprets some of it as commands.

   --colour[=WHEN], --color[=WHEN]
      Surround  the matching string with the marker find in GREP_COLOR
      environment variable. WHEN may be 'never', 'always', or 'auto'

   -c, --count
      Suppress normal output; instead print a count of matching  lines
      for  each  input  file.  With the -v, --invert-match option (see
      below), count non-matching lines.

   -D ACTION, --devices=ACTION
      If an input file is a device, FIFO or socket, use ACTION to pro-
      cess  it.   By default, ACTION is read, which means that devices
      are read just as if they were  ordinary  files.   If  ACTION  is
      skip, devices are silently skipped.

   -d ACTION, --directories=ACTION
      If  an  input file is a directory, use ACTION to process it.  By
      default, ACTION is read, which means that directories  are  read
      just  as if they were ordinary files.  If ACTION is skip, direc-
      tories are silently skipped.  If ACTION is recurse,  grep  reads
      all  files under each directory, recursively; this is equivalent
      to the -r option.

   -E, --extended-regexp
      Interpret PATTERN as an extended regular expression (see below).

   -e PATTERN, --regexp=PATTERN
      Use PATTERN as the pattern; useful to protect patterns beginning
      with -.

   -F, --fixed-strings
      Interpret PATTERN as a list of fixed strings, separated by  new-
      lines, any of which is to be matched.

   -P, --perl-regexp
      Interpret PATTERN as a Perl regular expression.

   -f FILE, --file=FILE
      Obtain  patterns  from  FILE, one per line.  The empty file con-
      tains zero patterns, and therefore matches nothing.

   -G, --basic-regexp
      Interpret PATTERN as a basic  regular  expression  (see  below).
      This is the default.

   -H, --with-filename
      Print the filename for each match.

   -h, --no-filename
      Suppress  the  prefixing  of  filenames  on output when multiple
      files are searched.

   --help Output a brief help message.

   -I     Process a binary file as if it did not  contain  matching  data;
      this is equivalent to the --binary-files=without-match option.

   -i, --ignore-case
      Ignore  case  distinctions  in  both  the  PATTERN and the input
      files.

   -L, --files-without-match
      Suppress normal output; instead print the  name  of  each  input
      file from which no output would normally have been printed.  The
      scanning will stop on the first match.

   -l, --files-with-matches
      Suppress normal output; instead print the  name  of  each  input
      file  from  which  output would normally have been printed.  The
      scanning will stop on the first match.

   -m NUM, --max-count=NUM
      Stop reading a file after NUM matching lines.  If the  input  is
      standard  input  from a regular file, and NUM matching lines are
      output, grep ensures that the standard input  is  positioned  to
      just  after the last matching line before exiting, regardless of
      the presence of trailing context lines.  This enables a  calling
      process  to resume a search.  When grep stops after NUM matching
      lines, it outputs any trailing context lines.  When  the  -c  or
      --count  option  is  also  used,  grep  does  not output a count
      greater than NUM.  When the -v or --invert-match option is  also
      used, grep stops after outputting NUM non-matching lines.

   --mmap If  possible, use the mmap(2) system call to read input, instead
      of the default read(2) system call.  In some situations,  --mmap
      yields  better performance.  However, --mmap can cause undefined
      behavior (including core dumps) if an input file  shrinks  while
      grep is operating, or if an I/O error occurs.

   -n, --line-number
      Prefix each line of output with the line number within its input
      file.

   -o, --only-matching
      Show only the part of a matching line that matches PATTERN.

   --label=LABEL
      Displays input actually coming from standard input as input com-
      ing  from  file LABEL.  This is especially useful for tools like
      zgrep, e.g.  gzip -cd foo.gz |grep -H --label=foo something

   --line-buffered
      Use line buffering, it can be a performance penality.

   -q, --quiet, --silent
      Quiet; do not write anything to standard output.   Exit  immedi-
      ately  with  zero status if any match is found, even if an error
      was detected.  Also see the -s or --no-messages option.

   -R, -r, --recursive
      Read all files under each directory, recursively; this is equiv-
      alent to the -d recurse option.

 --include=PATTERN
      Recurse in directories only searching file matching PATTERN.

 --exclude=PATTERN
      Recurse in directories skip file matching PATTERN.

   -s, --no-messages
      Suppress  error  messages about nonexistent or unreadable files.
      Portability note: unlike GNU grep, traditional grep did not con-
      form to POSIX.2, because traditional grep lacked a -q option and
      its -s option behaved like GNU grep's -q option.  Shell  scripts
      intended to be portable to traditional grep should avoid both -q
      and -s and should redirect output to /dev/null instead.

   -U, --binary
      Treat the file(s) as binary.  By default, under MS-DOS  and  MS-
      Windows,  grep  guesses the file type by looking at the contents
      of the first 32KB read from the file.  If grep decides the  file
      is  a  text  file, it strips the CR characters from the original
      file contents (to make regular expressions with  ^  and  $  work
      correctly).  Specifying -U overrules this guesswork, causing all
      files to be read and passed to the matching mechanism  verbatim;
      if  the  file is a text file with CR/LF pairs at the end of each
      line, this will cause some regular expressions  to  fail.   This
      option  has no effect on platforms other than MS-DOS and MS-Win-
      dows.

   -u, --unix-byte-offsets
      Report Unix-style byte offsets.   This  switch  causes  grep  to
      report  byte  offsets  as if the file were Unix-style text file,
      i.e. with CR characters stripped off.  This will produce results
      identical to running grep on a Unix machine.  This option has no
      effect unless -b option is  also  used;  it  has  no  effect  on
      platforms other than MS-DOS and MS-Windows.

   -V, --version
      Print  the  version number of grep to standard error.  This ver-
      sion number should be included in all bug reports (see below).

   -v, --invert-match
      Invert the sense of matching, to select non-matching lines.

   -w, --word-regexp
      Select only those  lines  containing  matches  that  form  whole
      words.   The  test is that the matching substring must either be
      at the beginning of the line, or preceded  by  a  non-word  con-
      stituent  character.  Similarly, it must be either at the end of
      the line or followed by a non-word constituent character.  Word-
      constituent  characters are letters, digits, and the underscore.

   -x, --line-regexp
      Select only those matches that exactly match the whole line.

   -y     Obsolete synonym for -i.

   -Z, --null
      Output a zero byte (the ASCII  NUL  character)  instead  of  the
      character  that normally follows a file name.  For example, grep
      -lZ outputs a zero byte after each  file  name  instead  of  the
      usual  newline.   This option makes the output unambiguous, even
      in the presence of file names containing unusual characters like
      newlines.   This  option  can  be  used  with commands like find
      -print0, perl -0, sort -z, and xargs  -0  to  process  arbitrary
      file names, even those that contain newline characters.

출처 : GREP 용 맨 페이지 다음을
입력하여 명령에 대해 배울 수 있습니다.

info <command>  

man <command>

whatis <command>

apropos <command>  

터미널에서.


3

당신은 귀하의 질문 태그 grep태그를. 그러나 먼저 다음을 참조grep 하는 태그 정보 를 읽는 것이 좋습니다 .

grep 표준 입력 또는 특정 표현식에 대한 파일에서 텍스트를 검색하고 일치하는 행을 리턴하는 데 사용되는 명령 행 유틸리티입니다.

일반적인 용도 grep는 로그 파일이나 프로그램 출력에서 ​​특정 줄을 찾아서 인쇄하는 것입니다.

사용 방법에 대한 자세한 내용 은이 Ubuntu 설명서 페이지 를 참조하십시오 grep.

또한 거의 모든 명령에는 읽을 수있는 매뉴얼 페이지가 있습니다. 귀하의 경우 다음 명령을 사용하십시오.

man grep

더욱, 당신은 이러한 명령 중 하나를 사용하여 GREP에 대한 정보를 얻을 수 있습니다 : info grep, grep -h, grep --help, whatis grep또는 apropos grep.


0

grep은 정규식을 기반으로 파일 내용을 검색합니다. 그것을 사용하는 가장 쉬운 방법은과 같은 것 grep "word" file.txt입니다.이 경우 file.txt에 "word"가 나타나는 모든 줄을 반환합니다 (없는 경우). 보다 고급 작업을 수행하려면 정규식에 대해 배우십시오. 검색하여 많은 자습서를 온라인으로 찾을 수 있습니다. http://lmgtfy.com/?q=grep+tutorial

개인적으로 터미널을 사용하기 위해 터미널을 사용하지 않는 것이 좋습니다. grep과 같은 복잡한 도구를 배우기 위해 많은 어려움을 겪을 수 있습니다. 좋아하는 해석 언어로 작성한 그래픽 프로그램이나 스크립트를 사용한다는 것을 발견하기 위해서입니다. 구식 터미널 명령을 배우는 것을 권장하는 대부분의 사람들은 구식 해커입니다.


터미널 기술은 Ubuntu를 사용하는 데 매우 유용합니다. 여기에있는 대부분의 질문에 터미널 사용과 관련된 솔루션이 있음을 알고 계셨습니까?
Binoy Babu

나는 가지고있다. 또한 GUI 솔루션이 작동하는 곳에서도 제공되는 경향이 있음을 알았습니다.
Wutaz

0

grep 명령은 하나 이상의 입력 파일에서 지정된 패턴과 일치하는 행을 찾습니다. 기본적으로 grep은 일치하는 줄을 인쇄합니다.

Grep은 지정된 PATTERN과 일치하는 행이있는 명명 된 입력 FILE (또는 파일이 명명되지 않은 경우 표준 입력 또는 파일 이름-제공)을 검색합니다. 기본적으로 grep은 일치하는 줄을 인쇄합니다.

또한 두 가지 변형 프로그램 인 egrep 및 fgrep을 사용할 수 있습니다. Egrep은 grep -E와 동일합니다. Fgrep은 grep -F와 동일합니다. 맨 페이지

SS64를 볼 수도 있습니다.

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.