Sed 一行程序将所有大写字母转换为小写字母?

我有一个文本文件,其中一些单词打印在所有大写。我希望能够只转换文本文件中的一切小写,使用 sed。这意味着第一句话就是,‘我有一个文本文件,其中一些单词全部用大写字母打印。’。'

216082 次浏览

tr:

# Converts upper to lower case
$ tr '[:upper:]' '[:lower:]' < input.txt > output.txt


# Converts lower to upper case
$ tr '[:lower:]' '[:upper:]' < input.txt > output.txt

或者,GNU 上的 sed(但不支持 BSD 或 Mac,因为它们不支持 \L\U) :

# Converts upper to lower case
$ sed -e 's/\(.*\)/\L\1/' input.txt > output.txt


# Converts lower to upper case
$ sed -e 's/\(.*\)/\U\1/' input.txt > output.txt
 

如果你愿意考虑一个不同的工具,你也可以很容易地用 awk做到这一点:

echo "UPPER" | awk '{print tolower($0)}'

如果使用 posx sed

为模式的任何情况选择(使用 sed 转换搜索的模式,而不是使用 regex 命令中的转换模式:

echo "${MyOrgPattern} | sed "s/[aA]/[aA]/g;s/[bB]/[bB]/g;s/[cC]/[cC]/g;s/[dD]/[dD]/g;s/[eE]/[eE]/g;s/[fF]/[fF]/g;s/[gG]/[gG]/g;s/[hH]/[hH]/g;s/[iI]/[iI]/g;s/[jJ]/[jJ]/g;s/[kK]/[kK]/g;s/[lL]/[lL]/g;s/[mM]/[mM]/g;s/[nN]/[nN]/g;s/[oO]/[oO]/g;s/[pP]/[pP]/g;s/[qQ]/[qQ]/g;s/[rR]/[rR]/g;s/[sS]/[sS]/g;s/[tT]/[tT]/g;s/[uU]/[uU]/g;s/[vV]/[vV]/g;s/[wW]/[wW]/g;s/[xX]/[xX]/g;s/[yY]/[yY]/g;s/[zZ]/[zZ]/g" | read -c MyNewPattern
YourInputStreamCommand | egrep "${MyNewPattern}"

用小写字母转换

sed "s/[aA]/a/g;s/[bB]/b/g;s/[cC]/c/g;s/[dD]/d/g;s/[eE]/e/g;s/[fF]/f/g;s/[gG]/g/g;s/[hH]/h/g;s/[iI]/i/g;s/j/[jJ]/g;s/[kK]/k/g;s/[lL]/l/g;s/[mM]/m/g;s/[nN]/n/g;s/[oO]/o/g;s/[pP]/p/g;s/[qQ]/q/g;s/[rR]/r/g;s/[sS]/s/g;s/[tT]/t/g;s/[uU]/u/g;s/[vV]/v/g;s/[wW]/w/g;s/[xX]/x/g;s/[yY]/y/g;s/[zZ]/z/g"

在 sed 中用大写字母替换//之间的小写字母

玩得开心

短,甜,你甚至不需要重定向: -)

perl -p -i -e 'tr/A-Z/a-z/' file

如果您有 GNU 扩展,您可以使用 sed 的 L (更低的整个匹配,或者直到达到 L [ low ]或 E [ end-toggle case off ]) ,如下所示:

sed 's/.*/\L&/' <input >output

注意: “ &”表示完全匹配模式。

顺便说一下,GNU 扩展包括 U (上)、 u (上下一个匹配字符)、 l (下下一个匹配字符)。例如,如果你想给一个句子套上骆驼皮:

$ sed -E 's/\w+/\u&/g' <<< "Now is the time for all good men..." # Camel Case
Now Is The Time For All Good Men...

注意: 因为假设我们有 GNU 扩展,所以我们可以使用 序列,比如 \w(匹配单词字符)和 -E(延期正则表达式)选项,这样你就不必转义一个或多个量词(+)和其他一些特殊的正则表达式字符。

以下是许多解决方案:

使用 perl、 tr、 sed 和 awk 进行大写

perl -ne 'print uc'
perl -npe '$_=uc'
perl -npe 'tr/[a-z]/[A-Z]/'
perl -npe 'tr/a-z/A-Z/'
tr '[a-z]' '[A-Z]'
sed y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/
sed 's/\([a-z]\)/\U\1/g'
sed 's/.*/\U&/'
awk '{print toupper($0)}'

小写为 perl、 tr、 sed 和 awk

perl -ne 'print lc'
perl -npe '$_=lc'
perl -npe 'tr/[A-Z]/[a-z]/'
perl -npe 'tr/A-Z/a-z/'
tr '[A-Z]' '[a-z]'
sed y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/
sed 's/\([A-Z]\)/\L\1/g'
sed 's/.*/\L&/'
awk '{print tolower($0)}'

从复杂的 bash 到小写:

while read v;do v=${v//A/a};v=${v//B/b};v=${v//C/c};v=${v//D/d};v=${v//E/e};v=${v//F/f};v=${v//G/g};v=${v//H/h};v=${v//I/i};v=${v//J/j};v=${v//K/k};v=${v//L/l};v=${v//M/m};v=${v//N/n};v=${v//O/o};v=${v//P/p};v=${v//Q/q};v=${v//R/r};v=${v//S/s};v=${v//T/t};v=${v//U/u};v=${v//V/v};v=${v//W/w};v=${v//X/x};v=${v//Y/y};v=${v//Z/z};echo "$v";done

从复杂的 bash 到大写:

while read v;do v=${v//a/A};v=${v//b/B};v=${v//c/C};v=${v//d/D};v=${v//e/E};v=${v//f/F};v=${v//g/G};v=${v//h/H};v=${v//i/I};v=${v//j/J};v=${v//k/K};v=${v//l/L};v=${v//m/M};v=${v//n/N};v=${v//o/O};v=${v//p/P};v=${v//q/Q};v=${v//r/R};v=${v//s/S};v=${v//t/T};v=${v//u/U};v=${v//v/V};v=${v//w/W};v=${v//x/X};v=${v//y/Y};v=${v//z/Z};echo "$v";done

从简单的 bash 到小写:

while read v;do echo "${v,,}"; done

从 bash 到大写:

while read v;do echo "${v^^}"; done

注意,${ v,}和 ${ v ^ }只更改第一个字母。

你应该这样使用它:

(while read v;do echo "${v,,}"; done) < input_file.txt > output_file.txt

如果您有 GNU sed (可能在 Linux 上,但不在 * BSD 或 macOS 上) :

echo  "Hello  MY name is SUJIT "  | sed 's/./\L&/g'

产出:

hello  my name is sujit

我喜欢这里的一些答案,但是有一个 sed 命令可以在任何平台上完成这个任务:

sed 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'

无论如何,这很容易理解,而且了解 y 命令有时也会派上用场。

不要写这么长的句子:

sed 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/' input

我们可以用这个:

sed 'y/'$(printf "%s" {A..Z} "/" {a..z} )'/' input