developer tip

모든 대문자를 소문자로 변환하는 sed one-liner?

optionbox 2020. 7. 26. 12:52
반응형

모든 대문자를 소문자로 변환하는 sed one-liner?


모든 단어로 일부 단어가 인쇄되는 텍스트 파일이 있습니다. 을 사용하여 텍스트 파일의 모든 것을 소문자로 변환하고 싶습니다 sed. 즉, 첫 번째 문장은 '모든 단어에 일부 단어가 인쇄 된 텍스트 파일이 있습니다.'라는 의미입니다.


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 sed는 지원하지 않습니다 \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

GNU 확장이있는 경우 다음과 같이 sed의 \ L (더 낮은 전체 일치 또는 \ L [lower] 또는 \ E [end-toggle casing off]에 도달 할 때까지)을 사용할 수 있습니다.

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

참고 : '&'는 전체 일치 패턴을 의미합니다.

참고로 GNU 확장명에는 \ U (상단), \ u (상단 다음 문자 일치), \ l (다음에 일치하는 문자 이하)이 포함됩니다. 예를 들어, 당신이 문장을 낙타로 만들고 싶다면 :

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

참고 : 가정에 GNU 확장이 있다고 가정하기 때문에 \ w (단어 문자)를 허용하고 캡처 괄호와 하나 이상을 피할 필요가없는 dash-r (확장 정규 표현식) 옵션을 사용할 수도 있습니다. 수량 자 (+). (제외 : \W [non-word], \s [whitespace], \S [non-whitespace]또한 대시-R에서 지원되지만 \d [digit]\D [non-digit]되지 않습니다.)


awk다른 도구를 기꺼이 고려하려는 경우을 사용하여이 작업을 매우 쉽게 수행 할 수도 있습니다 .

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

다음은 많은 솔루션입니다.

Perl, tr, sed 및 awk를 사용하는 upercaser

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

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

산출:

안녕 내 이름은 sujit

posix sed를 사용하는 경우

Selection for any case for a pattern (converting the searched pattern with this sed than use the converted pattern in you wanted command using 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}"

convert in lower case

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"

same for uppercase replace lower letter between // by upper equivalent in the sed

Have fun


short, sweet and you don't even need redirection :-)

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

I like some of the answers here, but there is a sed command that should do the trick on any platform:

sed 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'

Anyway, it's easy to understand. And knowing about the y command can come in handy sometimes.

참고URL : https://stackoverflow.com/questions/4569825/sed-one-liner-to-convert-all-uppercase-to-lowercase

반응형