实现了一种模拟windows排序的python方法,其排序规则为:
- 不处理浮点数
- 特殊字符(如:&、$、# 等)排在数字和字母之前;
- 数字优先于字母排序;
- 数字是连着的整数,应该按照整数进行排序;
- 小写字母排在大写字母前面;
- 英文字符按字母表顺序排序;
def custom_sort_key(str_value):
digital_res = ""
digital_flag = False
sort_list = []
rank_value = []
for c in str_value:
c_ascii = ord(c)
if c_ascii <= 57 and c_ascii >= 48:
digital_flag = True
digital_res += c
else:
if digital_flag:
digital_res = int(digital_res)
rank_value.append((1, digital_res))
digital_res = ""
digital_flag = False
if c_ascii <= 47 or (c_ascii >= 58 and c_ascii <= 64) or (c_ascii >= 91 and c_ascii <= 96) or c_ascii >= 123:
# special char
rank_value.append((0, c_ascii))
elif c_ascii >= 97 and c_ascii &

文章描述了一个Python函数custom_sort_key,它模仿Windows的排序规则,对文件名进行排序,考虑了特殊字符、数字、字母的顺序,适用于处理.bmp文件名列表。
最低0.47元/天 解锁文章
504

被折叠的 条评论
为什么被折叠?



