답변:
기본 답변 :
mylist = ["b", "C", "A"]
mylist.sort()
그러면 원래 목록이 수정됩니다 (즉, 내부 정렬). 원본을 변경하지 않고 정렬 된 목록의 사본을 얻으려면 다음 sorted()
함수를 사용하십시오 .
for x in sorted(mylist):
print x
그러나 위의 예제는 로케일을 고려하지 않고 대소 문자 구분 정렬을 수행하기 때문에 순진합니다. 선택적 매개 변수 key
를 사용하여 사용자 정의 정렬 순서를 지정할 수 있습니다 (를 사용하는 대안 cmp
은 여러 번 평가되어야하므로 사용되지 않는 솔루션 key
입니다. 요소 당 한 번만 계산 됨).
따라서 언어 별 규칙을 고려하여 현재 로캘에 따라 정렬하려면 cmp_to_key
functools의 도우미 기능입니다.
sorted(mylist, key=cmp_to_key(locale.strcoll))
마지막으로 필요한 경우 정렬을위한 사용자 지정 로캘 을 지정할 수 있습니다 .
import locale
locale.setlocale(locale.LC_ALL, 'en_US.UTF-8') # vary depending on your lang/locale
assert sorted((u'Ab', u'ad', u'aa'),
key=cmp_to_key(locale.strcoll)) == [u'aa', u'Ab', u'ad']
마지막 참고 :이 lower()
방법 을 사용하는 대소 문자를 구분하지 않는 정렬의 예를 볼 수 있습니다 -ASCII 하위 문자에만 작동하기 때문에 잘못되었습니다. 영어가 아닌 데이터에는이 두 가지가 잘못되었습니다.
# this is incorrect!
mylist.sort(key=lambda x: x.lower())
# alternative notation, a bit faster, but still wrong
mylist.sort(key=str.lower)
mylist.sort(key=str.lower)
가 더 빠르다.
[1, 2, 3].sort()
. 으로 sort()
각종 장소의 목록 (즉, 직접 목록을 변경)은 정렬 된 목록을 반환하고, 실제로 아무것도 반환하지 않으며, 인쇄 문 인쇄 그렇게하지 않습니다 None
. 당신이 변수에 목록을 저장 한 경우, 말 x
,라고 x.sort()
, 다음 print(x)
, 당신은 정렬 된 목록을 볼 것입니다.
문자열을 정렬하는 올바른 방법은 다음과 같습니다.
import locale
locale.setlocale(locale.LC_ALL, 'en_US.UTF-8') # vary depending on your lang/locale
assert sorted((u'Ab', u'ad', u'aa'), cmp=locale.strcoll) == [u'aa', u'Ab', u'ad']
# Without using locale.strcoll you get:
assert sorted((u'Ab', u'ad', u'aa')) == [u'Ab', u'aa', u'ad']
의 이전 예제는 mylist.sort(key=lambda x: x.lower())
ASCII 전용 컨텍스트에 적합합니다.
오래된 질문이지만 설정하지 않고 로케일 인식 정렬을 locale.LC_ALL
수행하려면 이 답변에서 제안한대로 PyICU 라이브러리 를 사용하면 됩니다 .
import icu # PyICU
def sorted_strings(strings, locale=None):
if locale is None:
return sorted(strings)
collator = icu.Collator.createInstance(icu.Locale(locale))
return sorted(strings, key=collator.getSortKey)
그런 다음 예를 들어 전화하십시오.
new_list = sorted_strings(list_of_strings, "de_DE.utf8")
이것은 로케일을 설치하거나 다른 시스템 설정을 변경하지 않고 나를 위해 일했습니다.
(이것은 이미 위의 의견에서 제안 되었지만 처음에는 직접 놓 쳤기 때문에 더 눈에 띄기를 원했습니다.)
아니면 :
names = ['Jasmine', 'Alberto', 'Ross', 'dig-dog']
print ("The solution for this is about this names being sorted:",sorted(names, key=lambda name:name.lower()))
간단합니다 : https://trinket.io/library/trinkets/5db81676e4
scores = '54 - Alice,35 - Bob,27 - Carol,27 - Chuck,05 - Craig,30 - Dan,27 - Erin,77 - Eve,14 - Fay,20 - Frank,48 - Grace,61 - Heidi,03 - Judy,28 - Mallory,05 - Olivia,44 - Oscar,34 - Peggy,30 - Sybil,82 - Trent,75 - Trudy,92 - Victor,37 - Walter'
점수 = scores.split ( ',') x 정렬 된 (점수) : print (x)
locale
현재 로케일에 따라 자연스럽게 정렬하는 문자열 조합 방법을 사용하십시오 .