python函數基本介紹

来源:https://www.cnblogs.com/liujiyu/archive/2018/05/28/9098197.html
-Advertisement-
Play Games

函數 1.函數結構 def 是函數的定義關鍵字,my_len是函數名。()傳參用,冒號下麵都是函數體。 執行函數方法:函數名加括弧來執行函數。My_len() 舉例: # s = 'lkfjsjulkjdgjdsf' # def my_len(): # count = 0 # for i in s: ...


函數

1.函數結構
   def 是函數的定義關鍵字,my_len是函數名。()傳參用,冒號下麵都是函數體。
   執行函數方法:函數名加括弧來執行函數。My_len()

    舉例:
    # s = 'lkfjsjulkjdgjdsf'
    # def my_len():
    # count = 0
    # for i in s:
    # count += 1
    #
    # print(my_len())

2.函數的封裝
  

  一個函數就是為了實現一個功能

3.Return 在函數中的作用,是給函數的執行者返回值

  return作用:

    1.終止函數
    2.給函數的執行者返回值

  retun後接值說明:

    Return後面不加任何東西,反悔結果是none
    Return,對於單個值來說,後面加什麼反回的就是什麼,是字元串就反回字元串,是數字就反回數字。
    Return 對於多個反回值時,會將多個值放到一個元組中,反回給函數的執行者。

      舉例:
        #def func1():
        # print(111)
        # print(222)
        # return
        # print(333)
        # print(func1()) ###終止函數反回預設值none
      結果:
        111
        222
        None

      舉例:
        #def func1():
        # print(111)
        # print(222)
        # return 666 ####反回666
        # return 'alex' ####反回'alex'
        # return 'alex', 666, [1, 2, 3] ###反回一個元組('alex', 666, [1, 2, 3])



4.函數的傳參
  函數傳參分為兩個方向:
    1. 實參角度
      ——實參就是在執行函數過程中向函數內傳入的參數。(函數執行裡面放的參數)
    2. 行參角度
      ——行參就是準備被賦值的名字,即在運行函數時準備接收行參的字元。(在函數定義的時裡面放的參數)

  註意:行參是不可以被改變得,而實參是可以改變的。

    舉例:
      # def my_len(argv): # argv是形式參數 ,形參
      #
      # count = 0
      # for i in argv:
      # count += 1
      # return count
      # s = 'lkfjsjulkjdgjdsf'
      # l1 = [1, 2, 3, 4, 5]
      # print(my_len(l1)) #l1是實際參數, 實參
    結果:
      5

  實參的類型:
    1.位置參數
    2.關鍵字參數
    3.混合參數

    (1)位置參數
        行參的參數要與實參位置按順序一一對應,也就是說在改行參傳參數的值,要與預先定義的行參位置一一對應,行參會第一個字元會對應接收實參的第一個字元,                              依次類推。

    (2)關鍵詞參數
        關鍵字參數不關心傳入參數放的順序位置,傳入參數要與行參關鍵字一致即可。

    (3)混合參數
        位置參數和關鍵字參數同時存在
        註:關鍵字參數,必須要在位置參數的後面

          舉例:
            # 位置參數 按照順序一一對應
            # def func1(a, b, c):
            # print(a, b, c)
            # func1(1, 2, 'alex') ###1,2,'alex'分別對應a,b,c

            # def max(a, b): return a if a > b else b
            # ret = 1 if 2 > 1 else 6
            # print(ret)
            # print(max(10, 2)) ###10,2,分別對應a,b

            # 關鍵字傳參 一一對應。
            # def func2(a, b):
            # print(a, b)
            # func2(b=2, a=3) ###關鍵字a=3 對應行參裡面的a,b=2對應行參裡面的b

            混合參數。(位置參數,關鍵字參數) 關鍵字參數必須在位置參數後面。
            # def func3(a, b, c, d):
            # print(a, b, c, d)
            # func3(1,2,d=3,c=5) ###關鍵字必須在位置參數後
    行參的類型:
      1.位置參數
      2.預設參數
      3.動態參數 (*args 、 **kwargs )

      (1)位置參數
          位置參數就是保證要與實參的位置參數保持一致

      (2)預設參數
          預設參數用的比較多,預設就是在不傳入參數的時候使用的參數即為預設參數,即在實參不輸入參數時,程式運行會使用預先定義好的預設參數,但手動輸入                                      後悔替換預設參數輸入。
          註意,預設參數要在位置參數的後面添加

      (3)動態參數(萬能參數)
          對參數的個數不固定的時候使用動態參數(萬能參數),即在執行函數時,實參傳入多少參數接收多少參數。

          (*args 、 **kwargs )動態參數有兩種:
          動態參數分為兩種(萬能參數)
            *args 接收所有的位置參數,所有的位置參數都放在一個元祖中。
            **kwargs 接收所有關鍵字參數,所有接收到的關鍵字都放在一個字典中。

              舉例:

                #預設參數:
                # def login(name,sex='男'): ###預設參數要在位置參數後面
                # # with open('register', encoding='utf-8', mode='a') as f1:
                # # f1.write('{},{}\n'.format(name,sex))
                # #
                # #
                # # while True:
                # # name = input('請輸入姓名:').strip()
                # # if '1' in name:
                # # login(name)
                # # else:
                # # sex = input('請輸入性別:').strip()
                # # login(name,sex)

                #萬能參數:
                # def func3(*args, **kwargs): #函數的定義的時候 * 代表聚合。
                # print(args)
                # print(kwargs)
                # # func3(1, 2, 3, 'alex', c=6, name='wusir', age='21') ###結果:(1, 2, 3, 'alex') {'c': 6, 'name': 'wusir', 'age': '21'}


    形參的排列順序:
      位置參數--> *args-->預設參數-->**kwargs

        舉例:
          # def func5(a,b,*args,sex='男',**kwargs):
          # print(a,b,)
          # print(args)
          # print(sex)
          # print(kwargs)

5.函數中星號的定義:
  (1)在函數定義的時候,*代表聚合
  (2)函數的執行時候,*代表打散 註意:字典打散時用**兩個星號

    舉例:
      # def func3(*args, **kwargs): #函數的定義的時候 * 代表聚合。
      # print(args)
      # print(kwargs)
      # func3(*[1, 2, 3],*(22, 33)) #函數的執行的時候 * 代表打散。 ###結果:(1, 2, 3, 22, 33) {}
      # func3(**{'name':"alex"},**{'age':23}) #函數的執行的時候 * 代表打散。 ###結果:() {'name': 'alex', 'age': 23}
      # func3(1, 2, 3, 22, 33) #函數的執行的時候 * 代表打散。 ###結果:(1, 2, 3, 22, 33) {}

 

6.函數的嵌套:(記住兩個關鍵點)
  代碼順序執行,當見到函數名加括弧,就是執行函數。
  函數在沒有執行完是不會執行下麵的內容的。

  註:
  執行一個函數就會開闢一個臨時空間進行存儲,即每個函數都會單獨開闢一個臨時空間使用存放函數體內容。

 


    舉例:
      # def func1():
      # print(666)
      #
      # def func2():
      # func1()
      # print(333)
      #
      # def func3():
      # func2()
      # print(222)
      # print(111)
      # func3()
      # print(555)

 

      # def func1():
      # name = 'susi'
      # print(name)
      # def func2():
      # name1 = 'git'
      # print(333)
      # print(444)
      # func2()
      # func1()

 


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

-Advertisement-
Play Games
更多相關文章
  • 內容:回調函數;阻塞/同步、非阻塞、和非同步區別;阻塞和非阻塞代碼實例 Node.js 回調函數Node.js 非同步編程的直接體現就是回調。非同步編程依托於回調來實現,但不能說使用了回調後程式就非同步化了。回調函數在完成任務後就會被調用,Node 使用了大量的回調函數,Node 所有 API 都支持回調函 ...
  • 使用背景: 為什麼使用: 定義: 為什麼選擇兩根連詞線(--)表示變數? 用法: 作用域: 使用:root 作用域來定義全局變數: 如果想讓某個變數只在部分元素/組件下可見,只需要在特定的元素下定義該變數: 媒體查詢也可以提供作用域: 下麵一個例子來展示偽類下的作用域(例如,:hover): ...
  • 最近兄弟團隊讓我去幫忙優化兩個頁面,前端用的react全家桶,後端用的python,上一次寫react代碼都過去一年了,順著以前的的學習思路,再捋順一下react的要點 組件的生命周期就是Reac的工作過程,就好比人有生老病死,自然界有日月更替,每個組件在網頁中也會有被創建、更新和刪除,如同有聲明的 ...
  • 可以利用js中函數的閉包進行封裝 通常我們可以用下麵這種方法進行一個封裝,這樣在外部引入我們寫的這個js文件後,就可以直接使用export.getUserId()這種形式去調用該函數 上面寫法等價於下麵這一種,下麵可能更易於理解,但都差不多,這樣就進行了封裝然後在其他地方就可以通過window的全局 ...
  • 工廠方法模式 簡單工廠類 簡單工廠模式屬於創建型模式,又稱靜態工廠方法(Static factory method)模式。其是由一個工廠對象決定創建出哪一種產品類的實例,可理解為不同工廠模式的一個特殊實現。 上述代碼對於修改開放了,違反了開放封閉原則。故而引出工廠方法模式,去解決這樣的矛盾。 GOF ...
  • 引言 之前就瞭解過kafka,看的似懂非懂,最近項目組中引入了 "kafka" ,剛好接著這個機會再次學習下。 Kafka在很多公司被用作分散式高性能消息隊列,kafka之前我只用過redis的list來做簡單的隊列處理,也還算好用,可能數據量比較小,也是單機運行,未出現過問題,用作輕量級消息隊列還 ...
  • 將springMVC進行了進一步的封裝。讓開發者更容易。 ...
  • Java開源生鮮電商平臺-團購模塊設計與架構(源碼可下載) 說明:任何一個電商系統中,對於促銷這塊是必不可少的,畢竟這塊是最吸引用戶的,用戶也是最愛的模塊之一,理由很簡單,便宜。 我的經驗是無論是大的餐飲點還是小的餐飲店,優惠與折扣永遠是說福他們進入平臺的最好的手段之一。(大企業叫做節約成本,小企業 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...