Existe uma maneira fácil de classificar as letras em uma string em ordem alfabética em Python?
Então para:
a = 'ZENOVW'
Eu gostaria de retornar:
'ENOVWZ'
Existe uma maneira fácil de classificar as letras em uma string em ordem alfabética em Python?
Então para:
a = 'ZENOVW'
Eu gostaria de retornar:
'ENOVWZ'
Respostas:
Você pode fazer:
>>> a = 'ZENOVW'
>>> ''.join(sorted(a))
'ENOVWZ'
''.join(sorted(a, reverse=True, key=str.lower))
pode ser usado para executar uma classificação sem distinção entre maiúsculas e minúsculas. Pode ser útil.
A solução Sorted () pode fornecer resultados inesperados com outras strings.
Lista de outras soluções:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower())))
' belou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s)))
' Bbelou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(s))
' BBbbbbeellou'
Se você quiser se livrar do espaço no resultado, adicione a função strip () em qualquer um dos casos mencionados:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower()))).strip()
'belou'
A função Python sorted
retorna o resultado baseado em ASCII para a string.
INCORRETO : No exemplo abaixo, e
e d
é por trás H
e W
devido é de valor ASCII.
>>>a = "Hello World!"
>>>"".join(sorted(a))
' !!HWdellloor'
CORRETO : Para escrever a sequência classificada sem alterar a caixa das letras. Use o código:
>>> a = "Hello World!"
>>> "".join(sorted(a,key=lambda x:x.lower()))
' !deHllloorW'
Se você deseja remover toda a pontuação e números. Use o código:
>>> a = "Hello World!"
>>> "".join(filter(lambda x:x.isalpha(), sorted(a,key=lambda x:x.lower())))
'deHllloorW'
o código pode ser usado para classificar as strings em ordem alfabética sem usar nenhuma função embutida do python
k = entrada ("Insira qualquer sequência novamente")
li = []
x = len(k)
for i in range (0,x):
li.append(k[i])
print("List is : ",li)
for i in range(0,x):
for j in range(0,x):
if li[i]<li[j]:
temp = li[i]
li[i]=li[j]
li[j]=temp
j=""
for i in range(0,x):
j = j+li[i]
print("After sorting String is : ",j)
Gostei muito da resposta com a função reduzir (). Aqui está outra maneira de classificar a string usando acumulate ().
from itertools import accumulate
s = 'mississippi'
print(tuple(accumulate(sorted(s)))[-1])
classificado (s) -> ['i', 'i', 'i', 'i', 'm', 'p', 'p', 's', 's', 's', 's' ]
tupla (acumular (classificado (s)) -> ('i', 'ii', 'iii', 'iiii', 'iiiim', 'iiiimp', 'iiiimpp', 'iiiimpps', 'iiiimppss', 'iiiimppsss ',' iiiimppssss ')
Estamos selecionando o último índice (-1) da tupla
sorted(a)
retornará uma lista classificada, portanto, para comparações de strings, você não precisajoin()
(consulte a resposta abaixo).