# sort() 函数对列表元素进行排序,(此方法只能适用于列表),针对列表排序
# sorted()对所有可迭代的对象进行排序操作,sorted排序之后生成新的列表,原始列表不变
# 1.列表排序
a=[3,2,4,7,5]
a.sort() #;排序(升序)
# b=sorted(a)
# print(b)
print(a)
a.sort(reverse=True) #降序
print(a)
a.reverse() #逆序,反序排序
print(a)
# 2.根据文件名称排序
names=['2.jpg','7.jpg', '12.jpg','1.jpg', '24.jpg', '4.jpg']
#sorted排序之后生成新的列表,原始列表不变,sort是针对需要排序的列表进行改变
files = sorted(names, key=lambda x: int(x.split(".")[0]))
print(names) #['2.jpg', '7.jpg', '12.jpg', '1.jpg', '24.jpg', '4.jpg']
print(files) #['1.jpg', '2.jpg', '4.jpg', '7.jpg', '12.jpg', '24.jpg']
names.sort(key=lambda x: int(x.split(".")[0]))
print(names) #['1.jpg', '2.jpg', '4.jpg', '7.jpg', '12.jpg', '24.jpg']
# 3.文件名称根据两个参数进行排序,先根据哪个排序就先写哪个
names=['page_001_table_002','page_001_table_001', 'page_002_table_002','page_002_table_001', 'page_003_table_001', 'page_004_table_001']
names.sort(key=lambda x: (int(x.split("_")[1]), int(x.split("_")[-1])))
print(names) #['page_001_table_001', 'page_001_table_002', 'page_002_table_001', 'page_002_table_002', 'page_003_table_001', 'page_004_table_001']
# 4.数组排序
names=[('刘六', 25), ('张三', 23), ('王五', 20), ('李四', 18)]
names.sort(key=lambda x: x[1])
print(names) #[('李四', 18), ('王五', 20), ('张三', 23), ('刘六', 25)]
# 5.字典排序
names = {'张三':23,'李四':18,'王五':20,'刘六':25}
files = dict(sorted(names.items(), key=lambda x: x[1]))
print(files) #{'李四': 18, '王五': 20, '张三': 23, '刘六': 25}
# 6.进阶:坐标排序
# 方法一:二维坐标,(x,y)可以参考3
# 方法二:OCR识别的文本行四点坐标排序,思路先对图片以及识别结果进行矫正,之后根据四点坐标的中心点坐标进行排序。(详情见python使用functools排序)
https://blog.csdn.net/weixin_47046791/article/details/128533113?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22128533113%22%2C%22source%22%3A%22weixin_47046791%22%7D