我正在尝试对以下列表进行排序:
['default.smt',
'Setup 19k Hz.smt',
'Setup 1k Hz.smt',
'Setup 3 Hz.smt',
'Setup 500 Hz.smt',
'Setup 55 Hz.smt',
'Setup 5k Hz.smt',
'Setup 9k Hz.smt']其中k是1000,因此例如9k是9000,并且应该出现在19k之前,即19000。
所以我需要我的列表看起来像这样:
['default.smt',
'Setup 3 Hz.smt',
'Setup 55 Hz.smt',
'Setup 500 Hz.smt',
'Setup 1k Hz.smt',
'Setup 5k Hz.smt',
'Setup 9k Hz.smt',
'Setup 19k Hz.smt']'default.smt'单元格可以是第一个,也可以是最后一个,我不介意这一点。
我该怎么做呢?
发布于 2020-08-02 18:36:22
您可以在自定义键函数中使用regex。在示例中,我使用了一个朴素的正则表达式,它在某些边缘情况下会失败,但您可以对其进行调整。
import re
regex = re.compile(r'(\d+)(k)?')
li = ['default.smt',
'Setup 19k Hz.smt',
'Setup 1k Hz.smt',
'Setup 3 Hz.smt',
'Setup 500 Hz.smt',
'Setup 55 Hz.smt',
'Setup 5k Hz.smt',
'Setup 9k Hz.smt']
def magic(e):
match = regex.findall(e)
if not match:
return -1
num, k = int(match[0][0]), match[0][1]
if k:
return num * 1000
return num
print(sorted(li, key=magic))输出
['default.smt',
'Setup 3 Hz.smt',
'Setup 55 Hz.smt',
'Setup 500 Hz.smt',
'Setup 1k Hz.smt',
'Setup 5k Hz.smt',
'Setup 9k Hz.smt',
'Setup 19k Hz.smt']发布于 2020-08-04 00:00:46
这个答案基本上是从the examples section of natsort's documentation复制/粘贴的。我所做的一切只是改变了细节。
>>> import re
>>> import natsort
>>>
>>> # Define how each unit will be transformed
>>> conversion_mapping = {
... "k": 1000, # kilo
... "M": 1000000, # mega
... # Extend suffixes as you need
... }
>>>
>>> # This regular expression searches for numbers and units
>>> all_units = "|".join(conversion_mapping.keys())
>>> float_re = natsort.numeric_regex_chooser(natsort.FLOAT | natsort.SIGNED)
>>> unit_finder = re.compile(r"({})({})".format(float_re, all_units), re.IGNORECASE)
>>>
>>> def unit_replacer(matchobj):
... """
... Given a regex match object, return a replacement string where units are modified
... """
... number = matchobj.group(1)
... unit = matchobj.group(2)
... new_number = float(number) * conversion_mapping[unit]
... return "{}".format(new_number)
...
>>> # Demo time!
>>> data = ['default.smt',
... 'Setup 19k Hz.smt',
... 'Setup 1k Hz.smt',
... 'Setup 3 Hz.smt',
... 'Setup 500 Hz.smt',
... 'Setup 55 Hz.smt',
... 'Setup 5k Hz.smt',
... 'Setup 9k Hz.smt']
>>> [unit_finder.sub(unit_replacer, x) for x in data]
['default.smt',
'Setup 19000.0 Hz.smt',
'Setup 1000.0 Hz.smt',
'Setup 3 Hz.smt',
'Setup 500 Hz.smt',
'Setup 55 Hz.smt',
'Setup 5000.0 Hz.smt',
'Setup 9000.0 Hz.smt']
>>>
>>> natsort.natsorted(data, key=lambda x: unit_finder.sub(unit_replacer, x), alg=natsort.LOWERCASEFIRST)
['default.smt',
'Setup 3 Hz.smt',
'Setup 55 Hz.smt',
'Setup 500 Hz.smt',
'Setup 1k Hz.smt',
'Setup 5k Hz.smt',
'Setup 9k Hz.smt',
'Setup 19k Hz.smt']这里的优点是,这不仅使用了natsort的健壮算法,而且您还可以使用natsort的浮点数正则表达式定义,这是is very thorough。
坦率地说,我是natsort的作者。
发布于 2020-08-02 18:53:20
我用replace()函数做到了这一点。您可以在不导入的情况下编写此代码。下面是我的代码:
def sortList(list):
sortedList = []
finalList = []
for elements in list:
if elements == "default.smt":
finalList.append(elements)
else:
elements = elements.replace("Setup ", "")
elements = elements.replace("k", "000")
elements = elements.replace("Hz.smt", "")
sortedList.append(int(elements))
sortedList.sort()
for elements in sortedList:
elements = str(elements).replace("000", "k")
finalList.append("Setup " + str(elements) + " Hz.smt")
return finalList
list = ['default.smt',
'Setup 19k Hz.smt',
'Setup 1k Hz.smt',
'Setup 3 Hz.smt',
'Setup 500 Hz.smt',
'Setup 55 Hz.smt',
'Setup 5k Hz.smt',
'Setup 9k Hz.smt']
print(sortList(list))输出如下:
['default.smt', 'Setup 3 Hz.smt', 'Setup 55 Hz.smt', 'Setup 500 Hz.smt', 'Setup 1k Hz.smt', 'Setup 5k Hz.smt', 'Setup 9k Hz.smt', 'Setup 19k Hz.smt']https://stackoverflow.com/questions/63214898
复制相似问题