一個單字中字母出現的次數?

一個單字中字母出現的次數?

我想找出一個單字中每個字母出現的次數。例如

輸入
aabbbddd 
輸出
a@2 b@3 c@0 d@3

如何使用 shell 腳本執行此操作?

答案1

您可以使用seduniqsort

$ echo -n "aabbbddd" | sed 's/\(.\)/\1\n/g'| sort | uniq -c
  2 a
  3 b
  3 d

上面的程式碼使用sed每個字元並將其替換為自身+換行符 ( \n)。現在,每個字元都在換行符上(並已排序),您可以使用它uniq -c來計算字元數。

筆記:此方法不會顯示其間出現次數為零的任何字元。

或顯示每個字母的計數

$ s="aabbbddd"; for i in {a..z}; do
     v=$(echo -n "$s" | grep -oi $i | wc -l); echo "$i : $v"; done
a : 2
b : 3
c : 0
d : 3
e : 0
f : 0
g : 0
h : 0
i : 0
j : 0
k : 0
l : 0
m : 0
n : 0
o : 0
p : 0
q : 0
r : 0
s : 0
t : 0
u : 0
v : 0
w : 0
x : 0
y : 0
z : 0

這是透過循環遍歷字母表中的所有字母來實現的:

 for i in {a..z}; do .... ; done

循環的每次迭代我們都會透過字串 grep 查找特定字符,並使用-o選項grep僅傳回這些匹配項。然後,我們計算wc -l找到的每個字母出現的次數,並將其儲存在變數中$v。然後我們顯示每次迭代:

 echo "$i : $v"

筆記:這種方法可以處理亂序的字串。

答案2

這些解決方案不區分大小寫:

start cmd:> echo aabbbddd | 
  awk -v FS= '{for (i=1;i<=NF;i++) a[tolower($i)]++;}; 
    END {for (key in a) print key ": " a[key];}'
a: 2
b: 3
d: 3

或對於完整的字母表:

start cmd:> echo Aabbbddd | 
  awk -v FS= '{for (i=1;i<=NF;i++) a[tolower($i)]++;};
    END {chars="abcdefghijklmnopqrstuvwxyz";
    for (i=1;i<27;i++) { key=substr(chars,i,1);print key ": " a[key]};}'
a: 2
b: 3
c: 
d: 3
e: 
f: 
g: 
h: 
i: 
j: 
k: 
l: 
m: 
n: 
o: 
p: 
q: 
r: 
s: 
t: 
u: 
v: 
w: 
x: 
y: 
z:

答案3

僅使用 shell(對於短字串更快):

#! /bin/bash -
input=${*:-'aabbbddd'}

tmp=$input
arr=()
maxlen=0
maxchar=''
while ((${#tmp})); do
    firstchar=${tmp:0:1}
    next=${tmp//"$firstchar"}
    len=$((${#tmp}-${#next}))
    arr+=("$firstchar: $len")
    if ((maxlen<len)); then
    maxlen=$len
    maxchar=$firstchar
    fi
    tmp=$next
done

printf '%s\n' "${arr[@]}" 
echo "The char \"$maxchar\" appear $maxlen times in \"$input\""

稱為:

$ ./script
a@2 b@3 d@3 
The char "b" appear 3 times in "aabbbddd"

相關內容