[python] list 정렬시 특징 정리
🚀 들어가며...
- 개발하면서 참 많이 사용하는 리스트.. 오늘은 그 리스트의 값들을 정렬시 특징들을 살펴보겠습니다.
📑 내용
정렬
- sort()
sort() 함수는 기본적으로 오름차순으로 정렬해주지만 return 값은 None입니다.
result = [3, 1, 4, 5, 2]
result.sort()
print(result.sort())
# None
- sorted(list)
원본 리스트는 변하지 않고 정렬한 리스트를 새로 만들고 싶은 경우에는 sorted()를 사용합니다.
result = [3, 1, 4, 5, 2]
sorted_result = sorted(result)
print(result)
print(sorted_result)
# [3, 1, 4, 5, 2]
# [5, 4, 3, 2, 1]
※ 리스트가 아닌 문자열 그 자체를 정렬하거나 튜플을 정렬하기 위해서는 sorted()를 사용합니다. (이유는 문자열은 이전글에서 설명했던 immutable 형식이기 때문입니다.)
여담으로 참고로 찾아보니 sort()가 return을 하지 않기 때문에 속도는 sorted()보다 더 빠르다고 합니다.
저는 주로 sorted()함수가 조건 걸어주기 더 용이한것 같아서 lambda와 연계하여 자주 사용합니다.
제가 실제로 쓰는 코드를 보여드리겠습니다.
cursor.execute(select_rec_common(data), data)
m_Dest = name_to_json(cursor)
p1g1 = list(filter(lambda x: x.get('grp') == 1, m_Dest))
sort1_p1g1 = sorted(p1g1, key=lambda x: x.get('str_1'))
resort1_p1g1 = sorted(p1g1, key=lambda x: x.get('str_1'), reverse=True)
sort2_p1g1 = sorted(p1g1, key=lambda x: x.get('str_2'))
resort2_p1g1 = sorted(p1g1, key=lambda x: x.get('str_2'), reverse=True)
p1g2 = list(filter(lambda x: x.get('grp') == 2, m_Dest))
p1g3 = list(filter(lambda x: x.get('grp') == 3, m_Dest))
한가지만 보여드리면, sort1_p1g1은 list형식의 m_Dest변수에서 grp키값이 1인 데이터들만 뽑은 리스트에서 str_1을 오름차순으로 정렬한 리스트를 리턴하게 됩니다.
🙋🏻♂️ 후기
앞선 immutable과 mutable 글을 보고 오셨다면 이해가 더 쉬우셨을 겁니다! 제가 기초를 강조하는 이유를 아시겠죠? ㅎㅎ
list(filter(lambda x: 조건, data)) 이 형식은 진짜 유용하고 깔끔하게 조건들을 뽑을수 있는 표현식이니 많이들 활용해보시고 익숙해지시기 바랍니다~
🔗 참고한 글
https://docs.python.org/ko/3/howto/sorting.html
정렬 HOW TO — Python 3.10.4 문서
정렬 HOW TO 저자 Andrew Dalke와 Raymond Hettinger 배포 0.1 파이썬 리스트에는 리스트를 제자리에서(in-place) 수정하는 내장 list.sort() 메서드가 있습니다. 또한, 이터러블로부터 새로운 정렬된 리스트를 만
docs.python.org