Pular para o conteúdo

SED - texto para maiúsculas, minúsculas, pascal case e camel case

Dica publicada em Shell Script / Expressões Regulares
Fábio Berbert de Paula fabio
Hits: 9.821 Categoria: Shell Script Subcategoria: Expressões Regulares
  • Indicar
  • Impressora
  • Denunciar
O Viva o Linux depende da receita de anúncios para se manter. Ative os cookies aqui para nos patrocinar.
Não conseguimos carregar os anúncios. Se usa bloqueador, considere liberar o Viva o Linux para nos patrocinar.

SED - texto para maiúsculas, minúsculas, pascal case e camel case

Dando sequência a série de dicas sobre o sed, hoje veremos como converter texto para maiúsculas, minúsculas, pascal case e camel case.

Converter em maiúsculas

Para converter todo o texto para letras maiúsculas (uppercase), use a seguinte sintaxe:

echo viva o linux | sed 's/^.*$/\U&/'
VIVA O LINUX

Onde:
  • s = substitua
  • /^.*$/ = tudo o que estiver entre o início e o fim do texto
  • \U = a partir daqui todas as letras serão UPPERCASE
  • & = todo o texto em que a primeira expressão combinou (^.*$)

Converter em minúsculas

A conversão para minúsculas segue a mesma linha, a única coisa que muda é o \U de UPPERCASE que vira \L de LOWERCASE:

echo VIVA O LINUX | sed 's/^.*$/\L&/'
viva o linux

Pascal Case

Pascal Case significa uma frase composta por todas palavras iniciando por uma letra maiúscula. Sendo assim vamos começar convertendo todo o texto para minúsculas e em seguida converter cada letra inicial para maiúscula:

echo vIVa O LInux | sed -E 's/^.*$/\L&/ ; s/\w+/\u&/g'
Viva O Linux

As novidades aqui ficam por conta de:
  • \w+ = combina com cada palavra do texto
  • \u = converte apenas a próxima letra para maiúsculo
  • g = global, necessário para processar todas as combinações

Camel Case

Camel Case se diferencia do Pascal Case na primeira letra da frase, que sempre começa por letra minúscula. Também irei remover os espaços em branco do texto:

echo vIVa O LInux | sed -E 's/^.*$/\L&/ ; s/\w+/\u&/2g ; s/\s//g'
vivaOLinux

As novidades aqui ficam por conta de:
  • s/\w+/\u&/2g - adicionei apenas o número 2 ali, onde 2g significa que só irei proceder com o replace a partir da segunda ocorrência do padrão
  • s/\s//g - e aqui removo todos os espaços em branco

 ____                                _ 
/ ___|  ___  ___   _   _  ___  _   _| |
\___ \ / _ \/ _ \ | | | |/ _ \| | | | |
 ___) |  __/  __/ | |_| | (_) | |_| |_|
|____/ \___|\___|  \__, |\___/ \__,_(_)
                   |___/               

O Viva o Linux depende da receita de anúncios para se manter. Ative os cookies aqui para nos patrocinar.
Não conseguimos carregar os anúncios. Se usa bloqueador, considere liberar o Viva o Linux para nos patrocinar.
O Viva o Linux depende da receita de anúncios para se manter. Ative os cookies aqui para nos patrocinar.
Não conseguimos carregar os anúncios. Se usa bloqueador, considere liberar o Viva o Linux para nos patrocinar.

Vim - como criar arquivo ou diretório pelo NERDTree

SSH sem senha não funciona? Eis a solução

Listar processos por consumo de memória

Miniaturas de vídeo no Dolphin/KDE (video thumbnails)

Visualizar arquivos em formato markdown (ex.: README.md) pelo terminal

Introdução ao awk

Sed - como salvar alterações no arquivo

Exibindo o nome completo dos pacotes instalados no Debian e derivados

Testando se uma variável é número em shell script

Informações completas sobre os arquivos numa pasta

#1 Comentário enviado por maurixnovatrento em 11/06/2020 - 23:44h

Essa dica é muito boa.

___________________________________
Conhecimento não se Leva para o Túmulo.

Contribuir com comentário

Entre na sua conta para comentar.