[轉載] Python列表排序 list.sort方法和內置函數sorted

參考鏈接: Python中的函數

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

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

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

一、list.sort方法?

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

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

來看一下代碼:?

# coding=utf-8

list_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內置函數的使用,現在已經掌握了~

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/540445.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/540445.shtml
英文地址,請注明出處:http://en.pswp.cn/news/540445.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java Thread類最終同步的void join(long time_in_ms)方法,帶有示例

線程類最終同步無效連接(long time_in_ms) (Thread Class final synchronized void join(long time_in_ms)) This method is available in package java.lang.Thread.join(long time_in_ms). 軟件包java.lang.Thread.join(long time_in_ms)中提供了此方法。 join(long time_in_…

RYU控制器安裝`

2019獨角獸企業重金招聘Python工程師標準>>> 同樣是參考了http://linton.tw/2014/02/11/note-how-to-set-up-ryu-controller-with-gui-component/的內容。 1. 由于Ubuntu中自帶有Python,因此直接開始安裝pip apt-get install python-pip apt-get i…

[轉載] mac開發者,你不得不知道的環境變更設置方法(如Java的環境變更 source命令 )

參考鏈接: 設置Java環境 Mac是基于Unix的,所有先來幾個常識與命令: Unix中雙引號單引號反引號(" )的區別 Unix中雙引號起到“弱引用”的作用:被引用的字符大部分被按照字符字面的意思解釋執行,除了了$,\,字符除外。 [因…

人形機器人正在美國史密森尼博物館中擔任導游的工作

Te article has been removed, please visit IncludeHelps home page for more articles 該文章已被刪除,請訪問IncludeHelp的主頁以獲取更多文章翻譯自: https://www.includehelp.com/News/a-humanoid-robot-is-doing-the-job-of-a-guide-in-the-smithsonian-museu…

normalizr API

APInormalizedenormalizeschemaArrayEntityObjectUnionValuesnormalize(data, schema)Normalizes input data per the schema definition provided. 根據提供的schema定義規范化輸入數據。data: required Input JSON (or plain JS object) data that needs normalization.schem…

[轉載] 【Java】基礎06:HelloWorld入門程序

參考鏈接: 從Hello World示例開始Java編程 HelloWorld它的中文意思是:“你好,世界”。 仿佛代表著計算機對世界說出來的第一句話,因為它簡潔實用,所以被作為入門程序廣泛使用。 Java程序開發三步驟:編…

[轉載] Java中的命名參數

參考鏈接: Java命名約定 創建具有許多參數的方法是一個主要的缺點。 每當需要創建這樣的方法時,就在空氣中聞一聞:這是代碼的味道。 強化單元測試,然后進行重構。 沒有借口,沒有屁股。 重構! 使用構建器模…

[轉載] JVM(一):JVM體系結構詳解

參考鏈接: JVM如何工作–JVM體系結構 JVM簡介 JVM是Java程序得以運行的平臺,也是Java程序可以跨平臺的底層支撐,從整體上來看,JVM的主要功能可以分為加載和執行兩大塊。其中類加載器負責.class文件的尋址與加載&#xff0…

數據庫連接池的設計思路及java實現

2019獨角獸企業重金招聘Python工程師標準>>> connectionPool.DBConnectionManager [java] view plain copy package connectionPool; import java.sql.Connection; import java.sql.Driver; import java.sql.DriverManager; import java.sql.SQLException; i…

[轉載] java虛擬機 jvm 出入java棧 棧空間內存分配

參考鏈接: Java虛擬機(JVM)堆棧區域 java棧空間是一塊線程私有的內存空間,java堆和程序數據密切相關,那么java棧就是和線程執行密切相關。線程最基本的執行行為就是函數的調用。每次函數調用其實是通過java棧傳遞數據的。 數據結構中的棧的…

SVN命令行更新代碼

命令列表 svn help查看幫助信息 Available subcommands: add auth blame (praise, annotate, ann) cat changeli…

[轉載] Java中Runtime的使用

參考鏈接&#xff1a; Java中的JVM的關閉掛鉤 1 JDK中Runtime的定義 http://blog.csdn.net/lysnow_oss/archive/2007/05/12/1606349.aspx <轉載> 那就首先說點Runtime類吧&#xff0c;他是一個與JVM運行時環境有關的類&#xff0c;這個類是Singleton的。我…

窄帶物聯網(NB-IoT)初步了解

哪有什么天生如此&#xff0c;只是我們天天堅持。既然總有人要贏的話&#xff0c;為什么不能是我呢&#xff1f;[TOC] 什么是NB-Iot? 基于蜂窩的窄帶物聯網&#xff08;Narrow Band Internet of Things, NB-IoT&#xff09;成為萬物互聯網絡的一個重要分支。NB-IoT構建于蜂窩網…

ai人工智能_人工智能能力問答中的人工智能不確定性

ai人工智能1) Which of the following is true with respect to uncertainty in AI systems? Uncertainty arises when we are not 100 percent confident in our decisionsWhenever uncertainty arises, there is needs to be an estimation taken for getting to any conclu…

[轉載] 弄懂JDK、JRE和JVM到底是什么

參考鏈接&#xff1a; JDK JRE和JVM之間的區別 首先是JDK JDK(Java Development Kit) 是 Java 語言的軟件開發工具包(SDK)。 在JDK的安裝目錄下有一個jre目錄&#xff0c;里面有兩個文件夾bin和lib&#xff0c;在這里可以認為bin里的就是jvm&#xff0c;lib中則是jvm工作所需要…

mcq 隊列_人工智能搜索問題能力問題解答(MCQ)

mcq 隊列1) The main Aim of the AI system is to provide a solution for real-life problems by acting and thinking humanly. Whenever an agent is confronted by a problem, what is the first step that it follows towards searching a solution to the problem? Sear…

JavaOne大事紀:IBM談OpenJ9和Open Liberty

JavaOne大會以IBM陳述其最近對開源社區的貢獻作為開場&#xff1a;OpenJ9、Open Liberty和MicroProfile。IBM杰出工程師John Duimovich做了“IBM和Java&#xff1a;助力下一代創新”的開場演講。\\讀者可以回看演講視頻。\\Duimovich說IBM之所以致力于推動Java生態系統的創新&a…

[轉載] JVM中對象的回收過程

參考鏈接&#xff1a; JVM是否創建Main類(具有main()的類)的對象 當我們的程序開啟運行之后就&#xff0c;就會在我們的java堆中不斷的產生新的對象&#xff0c;而這是需要占用我們的存儲空間的&#xff0c;因為創建一個新的對象需要分配對應的內存空間&#xff0c;顯然我的內…

c語言格式對齊填充_C ++中類的大小 課堂上的填充和對齊| 派生類的大小

c語言格式對齊填充Prerequisite: 先決條件&#xff1a; sizeof() operator in C/C C / C 中的sizeof()運算符 Size of struct in C C中的struct大小 We know that a struct size is not only the summation of all the data members, rather its the minimum sum guaranteed. …

ELK系列~對fluentd參數的理解

這段時候一直在研究ELK框架&#xff0c;主要集成在對fluentd和nxlog的研究上&#xff0c;國內文章不多&#xff0c;主要看了一下官方的API&#xff0c;配合自己的理解&#xff0c;總結了一下&#xff0c;希望可以幫到剛入行的朋友們&#xff01; Fluentd&#xff08;日志收集與…