1樓:匿名使用者
python中的sort()方法用於陣列排序,本文以例項形式對此加以詳細說明:
一、基本形式
列表有自己的sort方法,其對列表進行原址排序,既然是原址排序,那顯然元組不可能擁有這種方法,因為元組是不可修改的。
123x = [4, 6, 2, 1, 7, 9]x.sort()print x # [1, 2, 4, 6, 7, 9]
如果需要一個排序好的副本,同時保持原有列表不變,怎麼實現呢
12345
x =[4, 6, 2, 1, 7, 9]y = x[ : ]y.sort()print y #[1, 2, 4, 6, 7, 9]print x #[4, 6, 2, 1, 7, 9]
注意:y = x[:] 通過分片操作將列表x的元素全部拷貝給y,如果簡單的把x賦值給y:y = x,y和x還是指向同一個列表,並沒有產生新的副本。
另一種獲取已排序的列表副本的方法是使用sorted函式:
1234
x =[4, 6, 2, 1, 7, 9]y = sorted(x)print y #[1, 2, 4, 6, 7, 9]print x #[4, 6, 2, 1, 7, 9]
sorted返回一個有序的副本,並且型別總是列表,如下:
1print sorted('python') #['p', 'h', 'n', 'o', 't', 'y']
二、自定義比較函式
可以定義自己的比較函式,然後通過引數傳遞給sort方法:
12345678910111213
def comp(x, y):if x < y:return 1elif x > y:
return -1else:return 0 nums = [3, 2, 8 ,0 , 1]nums.sort(comp)print nums # 降序排序[8, 3, 2, 1, 0]nums.
sort(cmp) # 呼叫內建函式cmp ,升序排序print nums # 降序排序[0, 1, 2, 3, 8]
三、可選引數
sort方法還有兩個可選引數:key和reverse
1、key在使用時必須提供一個排序過程總呼叫的函式:
123x = ['mmm', 'mm', 'mm', 'm' ]x.sort(key = len)print x # ['m', 'mm', 'mm', 'mmm']
2、reverse實現降序排序,需要提供一個布林值:
123y = [3, 2, 8 ,0 , 1]y.sort(reverse = true)print y #[8, 3, 2, 1, 0]
2樓:匿名使用者
python 中 sort()方法直接對列表的物件進行排序,沒有返回值
關於python中的賦值變數的問題
是指向同一個記憶體地址的,python的賦值是隻是把變數的記憶體地址賦值給另一個變數,這一點可以使用python的內建方法id 來進行測試,對於你給的例子 我們假設 qh 這個字串在記憶體中的地址是a,ljq 在記憶體中的地址是b you qh 讓you變數指向a地址。me you 讓me變數和yo...
javascript中sort函式問題,引數那麼寫什麼意思
清風之無痕歲月 sort 方法 返回一個元素已經進行了排序的 array 物件。arrayobj.sort sortfunction 引數arrayobj 必選項。任意 array 物件。sortfunction 可選項。是用來確定元素順序的函式的名稱。如果這個引數被省略,那麼元素將按照 ascii...