私はこのような文字列のリストを持っています:
['Aden', 'abel']
大文字と小文字を区別せずにアイテムを並べ替えたい。だから私は取得したい:
['abel', 'Aden']
しかし、大文字は小文字の前に表示されるため、またはとsorted()
は逆になります。list.sort()
どうすればケースを無視できますか?すべてのリストアイテムを小文字にするソリューションを見てきましたが、リストアイテムの大文字と小文字を変更したくありません。
私はこのような文字列のリストを持っています:
['Aden', 'abel']
大文字と小文字を区別せずにアイテムを並べ替えたい。だから私は取得したい:
['abel', 'Aden']
しかし、大文字は小文字の前に表示されるため、またはとsorted()
は逆になります。list.sort()
どうすればケースを無視できますか?すべてのリストアイテムを小文字にするソリューションを見てきましたが、リストアイテムの大文字と小文字を変更したくありません。
Python 3.3+ には、str.casefold
ケースレス マッチング用に特別に設計されたメソッドがあります。
sorted_list = sorted(unsorted_list, key=str.casefold)
Python 2 では次を使用しますlower()
。
sorted_list = sorted(unsorted_list, key=lambda s: s.lower())
どちらにもメソッドがあるため、通常の文字列とユニコード文字列の両方で機能しますlower
。
Python 2 では、2 つの型の値を相互に比較できるため、通常の文字列と Unicode 文字列の混合に対して機能します。ただし、Python 3 はそのようには機能しません。バイト文字列と Unicode 文字列を比較することはできないため、Python 3 では正しいことを行い、1 つのタイプの文字列のリストのみをソートする必要があります。
>>> lst = ['Aden', u'abe1']
>>> sorted(lst)
['Aden', u'abe1']
>>> sorted(lst, key=lambda s: s.lower())
[u'abe1', 'Aden']
>>> x = ['Aden', 'abel']
>>> sorted(x, key=str.lower) # Or unicode.lower if all items are unicode
['abel', 'Aden']
Python 3ではユニコードですが、Python 2では、とstr
の両方で機能するこのより一般的なアプローチを使用できます。str
unicode
>>> sorted(x, key=lambda s: s.lower())
['abel', 'Aden']
これを試して、リストをその場でソートすることもできます。
>>> x = ['Aden', 'abel']
>>> x.sort(key=lambda y: y.lower())
>>> x
['abel', 'Aden']
python3では、使用できます
list1.sort(key=lambda x: x.lower()) #Case In-sensitive
list1.sort() #Case Sensitive
大文字と小文字を区別しない並べ替え、文字列をその場で並べ替える、Python 2 または 3 (Python 2.7.17 および Python 3.6.9 でテスト済み):
>>> x = ["aa", "A", "bb", "B", "cc", "C"]
>>> x.sort()
>>> x
['A', 'B', 'C', 'aa', 'bb', 'cc']
>>> x.sort(key=str.lower) # <===== there it is!
>>> x
['A', 'aa', 'B', 'bb', 'C', 'cc']
キーはkey=str.lower
です。簡単にコピーして貼り付けてテストできるように、これらのコマンドはコマンドだけでどのように見えるかを次に示します。
x = ["aa", "A", "bb", "B", "cc", "C"]
x.sort()
x
x.sort(key=str.lower)
x
ただし、文字列が Unicode 文字列の場合 ( のようにu'some string'
)、Python 2 でのみ (この場合は Python 3 ではありません)、上記のx.sort(key=str.lower)
コマンドは失敗し、次のエラーが出力されることに注意してください。
TypeError: descriptor 'lower' requires a 'str' object but received a 'unicode'
このエラーが発生した場合は、Unicode の並べ替えを処理する Python 3 にアップグレードするか、最初に次のようにリスト内包表記を使用して Unicode 文字列を ASCII 文字列に変換します。
# for Python2, ensure all elements are ASCII (NOT unicode) strings first
x = [str(element) for element in x]
# for Python2, this sort will only work on ASCII (NOT unicode) strings
x.sort(key=str.lower)
これを試して
def cSort(inlist, minisort=True):
sortlist = []
newlist = []
sortdict = {}
for entry in inlist:
try:
lentry = entry.lower()
except AttributeError:
sortlist.append(lentry)
else:
try:
sortdict[lentry].append(entry)
except KeyError:
sortdict[lentry] = [entry]
sortlist.append(lentry)
sortlist.sort()
for entry in sortlist:
try:
thislist = sortdict[entry]
if minisort: thislist.sort()
newlist = newlist + thislist
except KeyError:
newlist.append(entry)
return newlist
lst = ['Aden', 'abel']
print cSort(lst)
出力
['abel', 'Aden']