电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Python列表排序 list.sort方法和內置函數sorted用法

瀏覽:4日期:2022-06-25 08:18:51

很多時候我們獲取到一個列表后,這個列表并不滿足我們的需求,我們需要的是一個有特殊順序的列表.

這時候就可以使用list.sort方法和內置函數sorted,本文就是介紹list.sort方法和sorted內置函數的使用方法和區別.

一、list.sort方法

list.sort方法會就地排序列表,也就是說不會把原列表復制一份。這也是這個方法的返回值是None的原因,提醒您本方法不會新建一個列表。

在這種情況下返回None其實是Python的一個慣例:如果一個函數或者方法對對象進行的是就地改動,那它就應該返回 None,好讓調用者知道傳入的參數發生了變動,而且并未產生新的對象。

來看一下代碼:

# coding=utf-8list_a = [1, 2, 8, 3, 7, 9, 5, 7]# sort()方法沒有返回值list_b = list_a.sort()print('list_a: ', list_a)print(’list_b: ’, list_b)

運行結果:

list_a: [1, 2, 3, 5, 7, 7, 8, 9]list_b: None

用返回None來表示就地改動這個慣例有個弊端,那就是調用者無法將其串聯起來。而返回一個新對象的方法則正好相反,它們可以鏈式調用,從而形成連貫接口。

二、sorted內置函數

與 list.sort 相反,內置函數sorted會新建一個列表作為返回值。

這個方法可以接受任何形式的可迭代對象作為參數,甚至包括不可變序列或生成器,而不管sorted接受的是怎樣的參數,它最后都會返回一個列表。

代碼示例:

list_c = [1, 2, 8, 3, 7, 9, 5, 7]# sorted內置函數會返回一個排序后的新列表list_d = sorted(list_c)print('list_c: ', list_c)print(’list_d: ’, list_d)

運行結果:

list_c: [1, 2, 8, 3, 7, 9, 5, 7]list_d: [1, 2, 3, 5, 7, 7, 8, 9]

可以看到,使用內置函數sorted時,返回了一個新的列表,而原列表沒有發生改變。

這有兩種好處:

1.如果我們即需要使用原列表,也需要使用排序后的列表,或者說我們要將一個非列表的可迭代對象排序成列表,sorted都可以做到

2.有返回值時,我們可以進行鏈式調用

# 可以對非列表的可迭代對象排序生成列表str_e = ’python’list_e = sorted(str_e)print(list_e) # 鏈式調用str_f = ’-’.join(sorted(str_e)).upper().split(’-’)print(str_f)

運行結果:

[’h’, ’n’, ’o’, ’p’, ’t’, ’y’][’H’, ’N’, ’O’, ’P’, ’T’, ’Y’]三、關鍵字參數key和reverse

不管是 list.sort 方法還是 sorted 函數,都有兩個可選的關鍵字參數:

key:

接收一個只有一個參數的函數,這個函數會被用在序列里的每一個元素上,所產生的結果將是排序算法依賴的對比關鍵字。

比如說,在對一些字符串排序時,可以用 key=str.lower 來實現忽略大小寫的排序,或者是用 key=len 進行基于字符串長度的排序。key的默認值是恒等函數,也就是默認用元素自己的值來排序。

reverse:

如果被設定為 True,被排序的序列里的元素會以降序輸出(也就是說把最大值當作最小值來排序),reverse的默認值是 False.

phone = (’HUAWEI’, ’OPPO’, ’MI’, ’MEIZU’, ’VIVO’)# 按長度進行排序phone_list = sorted(phone, key=len)print(phone_list) phone_list_re = sorted(phone, key=len, reverse=True)print(phone_list_re)

運行結果:

[’MI’, ’OPPO’, ’VIVO’, ’MEIZU’, ’HUAWEI’][’HUAWEI’, ’MEIZU’, ’OPPO’, ’VIVO’, ’MI’]

上面的代碼中,第一次排序新建了一個按照長度排序的字符串列表。第二次排序是將按長度排序由升序變成了降序。

細心的您應該可以發現,第二次的結果并不是第一次排序的結果的完全翻轉。

OPPO和VIVO的長度都是4,reverse=True后,它們的相對位置跟第一次排序是一樣的。這是什么原因呢?

sorted和list.sort背后的排序算法都是Timsort,它是一種自適應算法,會根據原始數據的順序特點交替使用插入排序和歸并排序,以達到最佳效率。

Python的排序算法Timsort是穩定的(知道這一點就可以了),意思是就算兩個元素比不出大小,在每次排序的結果里它們的相對位置是固定的。

因為用到的排序算法是穩定的,也就是說在長度一樣時,OPPO和VIVO的相對位置不會改變。

關于list.sort()方法和sorted內置函數的使用,現在已經掌握了~

補充:python知識點,列表排序sort()和sorted()的區別?

sort()是列表類型的方法,只適用于列表;sorted()是內置函數,支持各種容器類型。它們都可以排序,且用法類似,但sort()是在原地排序的,不會返回排序后的列表,而sorted()是返回新的排序列表。

>>> help(list.sort)Help on method_descriptor:sort(...) L.sort(key=None, reverse=False) -> None -- stable sort *IN PLACE*>>> help(sorted)Help on built-in function sorted in module builtins:sorted(iterable, /, *, key=None, reverse=False) Return a new list containing all items from the iterable in ascending order. A custom key function can be supplied to customize the sort order, and the reverse flag can be set to request the result in descending order.本文僅簡單介紹排序用法。

例如列表L:

>>> L = [’python’, ’shell’, ’Perl’, ’Go’, ’PHP’]

使用sort()和sorted()排序L,注意sort()是對L直接原地排序的,不是通過返回值來體現排序結果的,所以無需賦值給變量。而sorted()則是返回排序后的新結果,需要賦值給變量才能保存排序結果。

>>> sorted(L)[’Go’, ’PHP’, ’Perl’, ’python’, ’shell’]>>> L[’python’, ’shell’, ’Perl’, ’Go’, ’PHP’]>>> L.sort()>>> L[’Go’, ’PHP’, ’Perl’, ’python’, ’shell’]

不難發現,sort()和sorted()默認都是升序排序的(A<B<...<Z<a<b<...<z)。它們都可以指定參數reverse=True來表示順序反轉,也就是默認得到降序:

>>> L.sort(reverse=True)>>> L[’shell’, ’python’, ’Perl’, ’PHP’, ’Go’]

在python 3.x中,sort()和sorted()不允許對包含不同數據類型的列表進行排序。也就是說,如果列表中既有數值,又有字符串,則排序操作報錯。

sort()和sorted()的另一個參數是key,它默認為key=None,該參數用來指定自定義的排序函數,從而實現自己需要的排序規則。

例如,上面的列表不再按照默認的字符順序排序,而是想要按照字符串的長度進行排序。所以,自定義這個排序函數:

>>> def sortByLen(s):... return len(s)

然后通過指定key = sortByLen的參數方式調用sort()或sorted(),在此期間還可以指定reverse = True:

>>> L = [’shell’, ’python’, ’Perl’, ’PHP’, ’Go’]>>> sorted(L,key=sortByLen)[’Go’, ’PHP’, ’Perl’, ’shell’, ’python’]5>>> L.sort(key=sortByLen,reverse=True)>>> L[’python’, ’shell’, ’Perl’, ’PHP’, ’Go’]

再例如,按照列表每個元素的第二個字符來排序。

def f(e): return e[1]L = [’shell’, ’python’, ’Perl’, ’PHP’, ’Go’]sorted(L, key=f)L.sort(key=f)

更多的排序方式,比如指定兩個排序依據,一個按字符串長度升序排,長度相同的按第2個字符降序排。用法其實很簡單,不過稍占篇幅,所以本文不解釋了。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 假肢-假肢价格-假肢厂家-河南假肢-郑州市力康假肢矫形器有限公司 | 自动螺旋上料机厂家价格-斗式提升机定制-螺杆绞龙输送机-杰凯上料机 | 华溶溶出仪-Memmert稳定箱-上海协烁仪器科技有限公司 | 节流截止放空阀-不锈钢阀门-气动|电动截止阀-鸿华阀门有限公司 | 武汉天安盾电子设备有限公司 - 安盾安检,武汉安检门,武汉安检机,武汉金属探测器,武汉测温安检门,武汉X光行李安检机,武汉防爆罐,武汉车底安全检查,武汉液体探测仪,武汉安检防爆设备 | 西安展台设计搭建_西安活动策划公司_西安会议会场布置_西安展厅设计西安旭阳展览展示 | 衡阳耐适防护科技有限公司——威仕盾焊接防护用品官网/焊工手套/焊接防护服/皮革防护手套 | 永嘉县奥阳陶瓷阀门有限公司 | 钢结构-钢结构厂房-钢结构工程[江苏海逵钢构厂] | 苹果售后维修点查询,苹果iPhone授权售后维修服务中心 – 修果网 拼装地板,悬浮地板厂家,悬浮式拼装运动地板-石家庄博超地板科技有限公司 | ASA膜,ASA共挤料,篷布色母料-青岛未来化学有限公司 | 上海logo设计 | 消泡剂_水处理消泡剂_切削液消泡剂_涂料消泡剂_有机硅消泡剂_广州中万新材料生产厂家 | 工业PH计|工业ph酸度计|在线PH计价格-合肥卓尔仪器仪表有限公司 济南画室培训-美术高考培训-山东艺霖艺术培训画室 | Akribis直线电机_直线模组_力矩电机_直线电机平台|雅科贝思Akribis-杭州摩森机电科技有限公司 | 加气混凝土砌块设备,轻质砖设备,蒸养砖设备,新型墙体设备-河南省杜甫机械制造有限公司 | 粤丰硕水性环氧地坪漆-防静电自流平厂家-环保地坪涂料代理 | 淘趣英语网 - 在线英语学习,零基础英语学习网站 | 培训中心-翰香原香酥板栗饼加盟店总部-正宗板栗酥饼技术 | 东莞精密模具加工,精密连接器模具零件,自動機零件,冶工具加工-益久精密 | 德国EA可编程直流电源_电子负载,中国台湾固纬直流电源_交流电源-苏州展文电子科技有限公司 | 河南mpp电力管_mpp电力管生产厂家_mpp电力电缆保护管价格 - 河南晨翀实业 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | 手机存放柜,超市储物柜,电子储物柜,自动寄存柜,行李寄存柜,自动存包柜,条码存包柜-上海天琪实业有限公司 | 多功能干燥机,过滤洗涤干燥三合一设备-无锡市张华医药设备有限公司 | 专注氟塑料泵_衬氟泵_磁力泵_卧龙泵阀_化工泵专业品牌 - 梭川泵阀 | 牛皮纸|牛卡纸|进口牛皮纸|食品级牛皮纸|牛皮纸厂家-伽立实业 | DDoS安全防护官网-领先的DDoS安全防护服务商 | 冷油器-冷油器换管改造-连云港灵动列管式冷油器生产厂家 | 根系分析仪,大米外观品质检测仪,考种仪,藻类鉴定计数仪,叶面积仪,菌落计数仪,抑菌圈测量仪,抗生素效价测定仪,植物表型仪,冠层分析仪-杭州万深检测仪器网 | 外贮压-柜式-悬挂式-七氟丙烷-灭火器-灭火系统-药剂-价格-厂家-IG541-混合气体-贮压-非贮压-超细干粉-自动-灭火装置-气体灭火设备-探火管灭火厂家-东莞汇建消防科技有限公司 | 换网器_自动换网器_液压换网器--郑州海科熔体泵有限公司 | 知名电动蝶阀,电动球阀,气动蝶阀,气动球阀生产厂家|价格透明-【固菲阀门官网】 | 散热器-电子散热器-型材散热器-电源散热片-镇江新区宏图电子散热片厂家 | 除甲醛公司-甲醛检测治理-杭州创绿家环保科技有限公司-室内空气净化十大品牌 | 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 | 南京兰江泵业有限公司-水解酸化池潜水搅拌机-絮凝反应池搅拌机-好氧区潜水推进器 | 食品机械专用传感器-落料放大器-低价接近开关-菲德自控技术(天津)有限公司 | 高低温试验箱-模拟高低温试验箱订制-北京普桑达仪器科技有限公司【官网】 | 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | 昆山PCB加工_SMT贴片_PCB抄板_线路板焊接加工-昆山腾宸电子科技有限公司 |