다음 텍스트가 포함된 파일이 있다고 가정해 보겠습니다.
hello hel-
lo world wor-
ld test test he-
lo words words
공백을 구분 기호로 사용하면
hello: 1
world: 1
wor:1
ld:1
he: 1
hel-: 1
test:2
lo: 2
words: 2
즉, 하이픈을 사용하여 두 줄을 구분하고 한 단어로 처리하는 단어를 어떻게 처리합니까?
답변1
이렇게 하면 트릭을 수행할 수 있습니다.
sed ':1;/-$/{N;b1};s/-\n//g;y/ /\n/' file | sort | uniq -c
답변2
Perl은 이에 편리합니다. -0777 스위치는 전체 파일을 단일 문자열로 변환합니다.
perl -0777 -ne '
s/-\n//g; # join the hyphenated words
$count{$_}++ for split; # count all the words
while (($k,$v) = each %count) {print "$k:$v\n"}
' file
world:2
helo:1
hello:2
words:2
test:2
출력은 특별한 순서가 없습니다.
더 모호한 것도 있습니다:티클. tclsh는 다른 언어처럼 선택의 폭이 넓지 않으므로 -e
한 줄의 코드에는 더 많은 작업이 필요합니다. 이는 파일의 단어 순서를 유지한다는 장점이 있습니다.
echo '
set fh [open [lindex $argv 1] r]
set data [read -nonewline $fh]
close $fh
foreach word [split [string map {"-\n" ""} $data]] {
dict incr count $word
}
dict for {k v} $count {puts "$k:$v"}
' | tclsh -- file
hello:2
world:2
test:2
helo:1
words:2
답변3
tr
++ sed
파이프를 사용하십시오 datamash
.
$ tr ' ' '\n' <file | sed '/-/N;s/-\n//' | datamash -s -g1 --output-delimiter=':' count 1
hello:2
helo:1
test:2
words:2
world:2