Linux에서 wc 명령을 사용하는 방법

0
210
Linux에서 wc 명령을 사용하는 방법
Fatmawati achmad zaenuri/Shutterstock.com

파일의 줄, 단어 및 바이트 수를 계산하는 것은 유용하지만 Linux의 실제 유연성은 wc 명령은 다른 명령과 함께 작업할 때 발생합니다. 한 번 보자.

wc 명령이란 무엇입니까?

그만큼 wc 명령은 작은 응용 프로그램입니다. 핵심 Linux 유틸리티 중 하나이므로 설치할 필요가 없습니다. 이미 Linux 컴퓨터에 있을 것입니다.

아주 짧은 단어로 그것이 하는 일을 설명할 수 있습니다. 파일 또는 파일 선택의 행, 단어 및 바이트 수를 계산하고 결과를 터미널 창에 인쇄합니다. 또한 STDIN 스트림에서 입력을 받을 수 있습니다. 즉, 처리하려는 텍스트를 파이프로 연결할 수 있습니다. 여기는 wc 가치를 더하기 시작합니다.

Linux에서 파이프를 사용하는 방법

관련된Linux에서 파이프를 사용하는 방법

이것은 “한 가지만 하고 잘 하라”는 Linux 만트라의 좋은 예입니다. 파이프 입력을 허용하기 때문에 다중 명령 주문에 사용할 수 있습니다. 앞으로 살펴보겠지만 이 작은 독립 실행형 유틸리티는 실제로 훌륭한 팀 플레이어입니다.

내가 사용하는 한 가지 방법 wc 내가 요리하고 있는 복잡한 명령이나 별칭의 자리 표시자입니다. 완성된 명령이 파일을 파괴하고 삭제할 가능성이 있는 경우, 저는 종종 다음을 사용합니다. wc 실제적이고 위험한 명령의 대명사로.

그렇게 하면 명령을 개발하는 동안 각 파일이 예상대로 처리되고 있다는 시각적 피드백을 받습니다. 구문과 씨름하는 동안 나쁜 일이 발생할 가능성은 없습니다.

간단한 wc 즉, 여전히 알아야 할 몇 가지 작은 단점이 있습니다.

화장실 시작하기

가장 간단한 사용법 wc 명령줄에 텍스트 파일의 이름을 전달하는 것입니다.

wc lorem.txt

한 줄의 긴 텍스트가 있는 파일과 함께 wc 사용

이로 인해 wc 파일을 스캔하고 행, 단어 및 바이트 수를 세어 터미널 창에 기록합니다.

단어는 공백으로 묶인 모든 것으로 간주됩니다. 실제 언어에서 나온 단어인지 아닌지는 중요하지 않습니다. 파일에 “frd g lkj”만 포함되어 있어도 여전히 세 단어로 계산됩니다.

줄은 캐리지 리턴이나 파일 끝으로 끝나는 일련의 문자입니다. 편집기 또는 터미널 창에서 줄이 줄 바꿈되는지 여부는 문제가 되지 않습니다. wc 캐리지 리턴이나 파일의 끝을 만나더라도 여전히 같은 줄입니다.

첫 번째 예에서는 전체 파일에서 한 줄을 찾았습니다. 다음은 “lorem.txt” 파일의 내용입니다.

cat lorem.txt

한 줄의 긴 파일 내용

캐리지 리턴이 없기 때문에 이 모든 것이 한 줄로 계산됩니다. 이것을 다른 파일 “lorem2.txt”와 비교하고 어떻게 wc 해석합니다.

wc lorem2.txt
cat lorem2.txt

라인이 많은 파일과 함께 wc 사용하기

이 시간, wc 캐리지 리턴이 텍스트에 삽입되어 특정 지점에서 새 줄을 시작하기 때문에 15줄을 계산합니다. 그러나 텍스트가 있는 줄을 세어 보면 12개만 있는 것을 알 수 있습니다.

나머지 세 줄은 파일 끝에 있는 빈 줄입니다. 여기에는 캐리지 리턴만 포함됩니다. 이 줄에 텍스트가 없더라도 새 줄이 시작되었으므로 wc 그것들을 그대로 계산합니다.

우리는 많은 파일을 wc 우리가 좋아하는 대로.

wc lorem.txt lorem2.txt

두 개의 파일과 함께 wc 사용

각 개별 파일에 대한 통계와 모든 파일에 대한 합계를 얻습니다.

명시적으로 명명된 파일 대신 일치하는 파일을 선택할 수 있도록 와일드카드를 사용할 수도 있습니다.

wc *.txt *.?

와일드카드와 함께 wc 사용

명령줄 옵션

기본적으로, wc 각 파일의 행, 단어 및 바이트를 표시합니다. 사용하는 것과 같습니다. -l (윤곽) -w (단어) 그리고 -c (바이트) 옵션.

wc lorem.txt
wc -l -w -c lorem.txt

줄, 단어 및 바이트 옵션과 함께 wc 사용

보고 싶은 그림의 조합을 지정할 수 있습니다.

wc -l lorem.txt

wc -w lorem.txt

wc -c lorem.txt

wc -l -c lorem.txt

옵션 조합과 함께 화장실 사용

에 의해 생성된 마지막 수치에 특별한 주의를 기울여야 합니다. -c (바이트) 옵션. 많은 사람들이 이것을 문자 수를 세는 것으로 착각합니다. 그것은 실제로 계산 바이트. 문자 수와 바이트 수는 동일할 수 있습니다. 하지만 항상 그런 것은 아닙니다.

“unicode.txt”라는 파일의 내용을 살펴보겠습니다.

cat unicode.txt

라틴어가 아닌 문자가 포함된 파일의 내용

세 단어와 비 라틴 알파벳 문자가 있습니다. 우리는 wc 기본 설정으로 파일 처리 바이트그리고 우리는 그것을 다시 할 것이지만 요청합니다 캐릭터 이랑 -m (문자) 옵션.

wc unicode.txt
wc -l -w -m unicode.txt

파일의 바이트 수를 계산한 다음 동일한 파일의 문자 수 계산

문자보다 바이트가 더 많습니다.

파일의 16진 덤프를 살펴보고 무슨 일이 일어나는지 봅시다. 그만큼 hexdump 명령의 -C (표준) 옵션은 파일의 바이트를 16행으로 표시하고 해당 일반 ASCII(있는 경우)가 행 끝에 표시됩니다. 해당 ASCII 문자가 없으면 마침표 “.“가 대신 표시됩니다.

hexdump -C unicode.txt

비 라틴 문자가 포함된 짧은 파일의 16진 덤프

ASCII에서 16진수 값은 0x20 공백 문자를 나타냅니다. 왼쪽에서 세 개의 값을 계산하면 다음 값이 공백 문자임을 알 수 있습니다. 따라서 처음 세 값은 0x62, 0x6f그리고 0x79 “소년”의 글자를 나타냅니다.

뛰어 넘다 0x20우리는 세 개의 16진수 값의 또 다른 집합을 봅니다. 0x63, 0x61그리고 0x74. 이 철자는 “고양이”입니다. 다음 공백 문자 위로 이동하면 “dog”의 문자에 대한 세 가지 값이 더 표시됩니다. 이것들은 0x64, 0x5f그리고 0x67.

“개”라는 단어 바로 뒤에는 공백 문자가 있습니다. 0x20, 그리고 5개의 16진수 값이 더 있습니다. 마지막 두 개는 캐리지 리턴, 0x0a.

다른 세 바이트는 비라틴 문자를 나타내며 녹색으로 표시됩니다. 유니코드 문자이며 인코딩하는 데 3바이트가 필요합니다. 이것들은 0xe1, 0xaf그리고 0x8a.

따라서 무엇을 계산하고 있는지 확인하고 바이트와 문자가 같을 필요는 없습니다. 일반적으로 바이트 수를 계산하는 것이 실제로 무엇인지 알려 주기 때문에 더 유용합니다. 내부에 파일. 문자로 계산하면 사물의 수를 알 수 있습니다. 대표 파일 내용으로.

관련된: ANSI 및 유니코드와 같은 문자 인코딩이란 무엇이며 어떻게 다릅니까?

파일에서 파일 이름 가져오기

파일 이름을 제공하는 또 다른 방법이 있습니다. wc . 파일 이름을 파일에 넣고 이름을 전달할 수 있습니다. 저것 파일 wc. 파일을 열고 파일 이름을 추출한 다음 명령줄에서 전달된 것처럼 처리합니다. 이를 통해 재사용을 위해 임의의 파일 이름 컬렉션을 저장할 수 있습니다.

하지만 문제가 있고 큰 문제입니다. 파일 이름은 다음과 같아야 합니다. 없는 종료, 종료 캐리지 리턴 종료. 즉, 각 파일 이름 뒤에는 null 바이트가 있어야 합니다. 0x00 일반적인 캐리지 리턴 바이트 대신 0x0a.

이 형식으로 편집기를 열고 파일을 만들 수 없습니다. 일반적으로 이와 같은 파일은 다른 프로그램에서 생성됩니다. 그러나 이러한 파일이 있는 경우 이 방법을 사용합니다.

여기에 파일 이름이 포함된 파일이 있습니다. 에서 열기 less 당신에게 이상한 것을 보여줍니다 “^@“라는 문자 less 널 바이트를 나타내는 데 사용합니다.

less source-files-list.txt

null 바이트를 포함하는 less 파일

파일을 사용하려면 wc우리는 사용해야합니다 --files0-from (입력 읽기) 옵션을 선택하고 파일 이름이 포함된 파일 이름을 전달합니다.

wc ---files0-from=source-files-list.txt

null로 끝나는 파일 이름의 파일을 처리하는 wc

파일은 명령줄에 제공된 것처럼 정확하게 처리됩니다.

화장실에 배관 입력

입력을 보내는 훨씬 더 일반적이고 유연하며 생산적인 방법입니다. wc 다른 명령의 출력을 다음으로 파이프하는 것입니다. wc . 우리는 이것을 증명할 수 있습니다 echo 명령.

echo "Count this for me" | wc
echo -e "Count thisnfor me" | wc

echo를 사용하여 wc에 입력 보내기

두번째 echo 명령은 다음을 사용합니다. -e (이스케이프 문자) “와 같은 이스케이프 시퀀스를 허용하는 옵션n” 개행 서식 코드. 이것은 새로운 라인을 주입하여 wc 입력을 두 줄로 봅니다.

다음은 입력을 서로 공급하는 일련의 명령입니다.

find ./* -type f | rev | cut -d'.' -f1 | rev | sort | uniq
  • 찾기 파일을 찾습니다(type -f) 재귀적으로 현재 디렉토리에서 시작합니다. rev 파일 이름을 뒤집습니다.
  • 자르다 첫 번째 필드(-f1) 필드 구분 기호를 마침표로 정의하여 “.” 그리고 반전된 파일 이름의 “앞”에서 찾은 첫 번째 마침표까지 읽습니다. 이제 파일 확장자를 추출했습니다.
  • 신부님 추출된 첫 번째 필드를 뒤집습니다.
  • 종류 알파벳 오름차순으로 정렬합니다.
  • 유니크 터미널 창에 고유한 항목을 나열합니다.

현재 디렉토리 트리의 고유 확장자 목록

이 명령은 현재 디렉토리와 모든 하위 디렉토리에 있는 고유한 파일 확장자를 모두 나열합니다.

추가하면 -c (카운트) 옵션 uniq 그것을 계산할 명령 발생 각 확장 유형의. 그러나 서로 다른 고유한 파일 확장자가 얼마나 많은지 알고 싶다면 삭제할 수 있습니다. wc 줄의 마지막 명령으로 사용하고 -l (선) 옵션.

find ./* -type f | rev | cut -d'.' -f1 | rev | sort | uniq | wc -l

고유 확장을 계산하기 위해 wc 추가

관련된: Linux cut 명령을 사용하는 방법

그리고 마지막으로

마지막 트릭이 하나 있습니다. wc 당신을 위해 할 수 있습니다. 파일에서 가장 긴 줄의 길이를 알려줍니다. 슬프게도, 어떤 라인인지 알려주지 않습니다. 그것은 단지 당신에게 길이를 제공합니다.

wc -L taf.c

wc를 사용하여 파일에서 가장 긴 줄의 길이 얻기

그러나 탭은 8개의 공백으로 계산됩니다. 내 편집기에서 보면 해당 줄의 시작 부분에 세 개의 공백 탭이 있습니다. 실제 길이는 124자입니다. 따라서 보고된 수치는 인위적으로 확장된 것입니다.

나는 이 기능을 약간의 소금으로 처리할 것입니다. 그리고 사용하지 말라는 뜻입니다. 그 출력은 오해의 소지가 있습니다.

그 단점에도 불구하고, wc 파일의 단어뿐만 아니라 모든 종류의 값을 계산해야 할 때 파이프된 명령에 드롭하는 훌륭한 도구입니다.

관련된: 알아야 할 37가지 중요한 Linux 명령