Python教程:list.sort()和函數sorted(list)

来源:https://www.cnblogs.com/xxpythonxx/archive/2022/08/25/16624293.html
-Advertisement-
Play Games

《貝葉斯思維統計建模的PYTHON學習法》pdf高清版下載地址 內容簡介 · · · · · · 這本書幫助那些希望用數學工具解決實際問題的人們,僅有的要求可能就是懂一點概率知識和程式設計。而貝葉斯方法是一種常見的利用概率學知識去解決不確定性問題的數學方法,對於一個電腦專業的人士,應當熟悉其應用在 ...


1.sort()是列表的方法,修改原列表使得它按照大小排序,沒有返回值,返回None

In [90]: x = [4, 6, 2, 1, 7, 9]

In [91]: x.sort()

In [92]: x
Out[92]: [1, 2, 4, 6, 7, 9]
In [98]: aa = x.sort()
In [99]: aa #  返回None

2.sorted()是函數,不改變列表,重新生成一個按大小排序的列表

In [94]: a = sorted(x)
In [95]: a
Out[95]: [1, 2, 4, 6, 7, 9]

In [96]: x
Out[96]: [4, 6, 2, 1, 7, 9]

3.可選參數 列表sort方法還有兩個可選參數:key和reverse

## 1、key在使用時必須提供一個排序過程總調用的函數:
x = ['mmm', 'mm', 'mm', 'm']
x.sort(key=len)
print(x)  # 輸出 ['m', 'mm', 'mm', 'mmm']

## 2、reverse實現降序排序,需要提供一個布爾值:
y = [3, 2, 8, 0, 1]
y.sort(reverse=True)
print(y)  # [8, 3, 2, 1, 0]

4.優先順序排序(具體的我也不太懂)

def sort_priority(values,group):
    def helper(x):
        if x in group:
            print('在group',0,x)
            return (0,x)
            # print(values)
        print('不在group',1,x)
        return (1,x)
    values.sort(key=helper)
    # values.sort()

numbers = [8,3,1,2,5,4,7,6]
group = {2,3,5,7}
sort_priority(numbers,group)
print(numbers)

輸出:

不在group 1 8
在group 0 3
不在group 1 1
在group 0 2
在group 0 5
不在group 1 4
在group 0 7
不在group 1 6
[2, 3, 5, 7, 1, 4, 6, 8]

這個函數之所以能夠正常運作,是基於下列三個原因:

  • Python支持閉包( closure):閉包是一種定義在某個作用域中的函數,這種函數引用了那個作用域裡面的變數。helper函數之所以能夠訪問sort_priority的group參數,原因就在於它是閉包。
  • Python的函數是一級對象(first-class object),也就是說,我們可以直接引用函數、把函數賦給變數、把函數當成參數傳給其他函數,並通過表達式及if語句對其進行比較和判斷,等等。於是,我們可以把 helper這個閉包函數,傳給sort方法的key參數。
  • Python使用特殊的規則來比較兩個元組°。它首先比較各元組中下標為0的對應元素,如果相等,再比較下標為1的對應元素,如果還是相等,那就繼續比較下標為2的對應元素,依次類推。

5.閉包修改標誌變數

def sort_priority2(values,group):
    found = False
    def helper(x):
        if x in group:
            found = True
            return (0,x)
        return (1,x)
    values.sort(key=helper)
    return found
numbers = [8,3,1,2,5,4,7,6]
group = [8,5,2,3,4,7,9]
found = sort_priority2(numbers,group)
print('最後的numbers',numbers)
print("found",found)
輸出:最後的numbers [2, 3, 4, 5, 7, 8, 1, 6]
found False

6.閉包修改標誌變數2, 新增nonlocal

下麵用nonlocal來實現這個函數:

Python 3中有一種特殊的寫法,能夠獲取閉包內的數據。我們可以用nonlocal語句來表明這樣的意圖,也就是:給相關變數賦值的時候,應該在上層作用域中查找該變數。

nonlocal的唯一限制在於,它不能延伸到模塊級別,這是為了防止它污染全局作用域。

def sort_priority2(values,group):
    found = False
    def helper(x):
        if x in group:
            nonlocal found
            found = True
            return (0,x)
        return (1,x)
    values.sort(key=helper)
    return found
numbers = [8,3,1,2,5,4,7,6]
group = [8,5,2,3,4,7,9]
found = sort_priority2(numbers,group)
print('最後的numbers',numbers)
print("found",found)
輸出:最後的numbers [2, 3, 4, 5, 7, 8, 1, 6]
found True

nonlocal語句清楚地表明:如果在閉包內給該變數賦值,那麼修改的其實是閉包外那個作用域中的變數。這與global語句互為補充,global用來表示對該變數的賦值操作,將會直接修改模塊作用域里的那個變數。

然而,nonlocal也會像全局變數那樣,遭到濫用,所以,建議大家只在極其簡單的函數里使用這種機制。nonlocal的副作用很難追蹤,尤其是在比較長的函數中,修飾某變數的nonlocal語句可能和修改該變數的賦值操作離得比較遠,從而導致代碼更加難以理解。

如果使用nonlocal的那些代碼,已經寫得越來越複雜,那就應該將相關的狀態封裝成輔助類(helper class)。下麵定義的這個類,與nonlocal所達成的功能相同。它雖然有點長,但是理解起來相當容易(其中有個名叫_call_的特殊方法

'''
學習中遇到問題沒人解答?小編創建了一個Python學習交流群:711312441
尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書!
'''
class Sorter(object):
    def __init__(self,group):
        self.group = group
        self.found = False
    def __call__(self,x):
        if x in self.group:
            self.found = True
            return (0,x)
        return (1,x)
group = [8,5,2,3,4,7,9]
numbers = [8,3,1,2,5,4,7,6]
sorter = Sorter(group)
numbers.sort(key=sorter)
assert sorter.found is True
print(sorter.found)

sorted的關鍵字排序

student_tuples = [
    ('john', 'A',20, 15),
    ('jane', 'B',21, 12),
    ('dave', 'B', 22,10),
 ]
print(sorted(student_tuples, key=lambda student: student[0]))   # sort by age
# [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
def f(x):
    return len(x)
L.sort(key=f) #reverse = True #怎樣在此處天加速reverse
print (L)

輸出:

student_tuples = [
    ('john', 'A',20, 15),
    ('jane', 'B',21, 12),
    ('dave', 'B', 22,10),
 ]
print(sorted(student_tuples, key=lambda student: student[0]))   # sort by age
# [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
def f(x):
    return len(x)
L.sort(key=f) #reverse = True #怎樣在此處天加速reverse
print (L)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、獲取bean實例的三種方式 1.1 id 屬性 1.1.1 jar <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <spring.version>4.3.18.RELEASE</sp ...
  • 最近寫項目發現pythoncom 導入 win32api、win32con、win32com、win32gui 等win32相關的包都會出現或多或少問題,Google一大堆不靠譜的方法試了個遍。 特此記錄一下解決辦法 ...
  • 前言 1,在一些特定的場景我們往往需要看一下介面的入參,特別是跨系統的介面調用(下發,推送),這個時候的介面入參就很重要,我們保存入參入庫,如果出問題就可以馬上定位是上游還是下游的問題(方便扯皮) 2,還有一般需要在系統中看普通日誌,還有特殊的異常(報錯)日誌,一般我們可以通過伺服器去查看相應的位置 ...
  • 泛型—— 一種可以接收數據類型的數據類型,本文將通俗講解Java泛型的優點、方法及相關細節。 一、泛型的引入 我們都知道,繼承是面向對象的三大特性之一,比如在我們向集合中添加元素的過程中add()方法里填入的是Object類,而Object又是所有類的父類,這就產生了一個問題——添加的類型無法做到統 ...
  • 在練習格式化輸出時出現錯誤TypeError: can't multiply sequence by non-int of type 'float' 為什麼會出現TypeError:不能將序列乘以’float’類型的非整數? 實際情況是,這裡隱藏著一個優先順序的問題 我們發現一般情況下我們在格式化輸出 ...
  • docker-compose容器編排 為什麼使用docker-compose ​ 我們學會了使用 dockerfile 構建 docker 鏡像,看起來已經能夠滿足我們的日常需求了,無論需要什麼環境,在 dockerfile 里逐步構建,然後 build、run,就 ok 了,也滿足了我們docke ...
  • 《零起點Python機器學習快速入門》PDF高清版下載地址 內容簡介 · · · · · · 《零起點Python機器學習快速入門》採用獨創的黑箱模式,MBA案例教學機制,結合一線實戰案例,介紹 Sklearn人工智慧模塊庫和常用的機器學習演算法。《零起點Python機器學習快速入門》中配備大量圖表說 ...
  • 你們知道,“當任務數超過線程池的核心線程數時,如何讓它不進入隊列,而是直接啟用最大線程數”嗎? 大家好,我是Mic,一個工作了14年的Java程式員。 剛剛這個問題是一個工作5年的粉絲最近去某互聯網公司面試遇到的。 關於這個問題,我把高手的回答整理到了一個15W字的面試文檔裡面。 大家可以私信我領取 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...