# 裝飾器
> 原文: [https://pythonbasics.org/decorators/](https://pythonbasics.org/decorators/)
在本教程中學習 **Python 裝飾器**。
使用裝飾器向現有函數添加功能。 這稱為元編程。
一個函數可以將一個函數作為參數(要修飾的函數),并返回帶或不帶擴展名的相同函數。
擴展函數有時非常有用,我們將在本文稍后展示真實的示例。
### 函數是對象
在 Python 中,一切都是對象,包括函數。 這意味著函數可以傳遞并返回。 當您看到它時,乍一看可能很奇怪:
```py
def hello():
print("Hello")
# even functions are objects
message = hello
# call new function
message()
```
調用`message()`或`hello()`方法,它們具有相同的輸出。 那是因為他們指的是同一個對象。
現在讓我們繼續裝飾。
## 裝飾器
### 示例
裝飾器接受一個函數,對其進行擴展并返回。 是的,**函數可以返回函數**。
```py
def hello(func):
def inner():
print("Hello ")
func()
return inner
def name():
print("Alice")
obj = hello(name)
obj()
```
在上面的示例中,`hello()`是裝飾器。
在
語句中
```py
obj = hello(name)
```
函數`name()`由函數`hello()`裝飾。
它將函數包裝在另一個函數中。

### 示例 2
可以通過包裝函數來擴展它們。
```py
def who():
print("Alice")
def display(func):
def inner():
print("The current user is : ", end="")
func()
return inner
if __name__ == "__main__":
myobj = display(who)
myobj()
```
`who()`函數由`display()`裝飾。
### 語法糖
裝飾器是常見的,可以簡化。 盡管功能完全相同,但代碼更簡潔。
Python 可以使用**`@`符號**簡化裝飾器的使用。
```py
@hello
def name():
print("Alice")
if __name__ == "__main__":
name()
```
這將輸出完全相同的內容,但是是編寫代碼的更簡潔的方法。
跟我在一起。調用:
```py
@hello
def name():
```
只是一種更簡單的書寫方式:
```py
obj = hello(name)
```
在這兩種情況下,我們都將裝飾器應用于函數。
### 參數
參數可以與裝飾器一起使用。 如果您有一個打印總和`a + b`的函數,例如
```py
def sumab(a,b):
summed = a + b
print(summed)
```
您可以將其包裝在裝飾器函數中。以下示例顯示了如何執行此操作:
```py
def pretty_sumab(func):
def inner(a,b):
print(str(a) + " + " + str(b) + " is ", end="")
return func(a,b)
return inner
@pretty_sumab
def sumab(a,b):
summed = a + b
print(summed)
if __name__ == "__main__":
sumab(5,3)
```
函數`sumab`由函數`pretty_sumab`包裝。 這用其上方的`@`符號表示。
調用函數`sumab`,并查看帶有參數的函數`sumab`和`pretty_sumab`的邏輯都已運行。
### 真實示例
**用例:時間測量**

裝飾器可用于測量函數執行所需的時間。
如果您定義了一個休眠的簡單函數,則
```py
def myFunction(n):
time.sleep(n)
```
然后,您只需添加`@measure_time`行即可測量所需的時間
下面的例子:
```py
import time
def measure_time(func):
def wrapper(*arg):
t = time.time()
res = func(*arg)
print("Function took " + str(time.time()-t) + " seconds to run")
return res
return wrapper
@measure_time
def myFunction(n):
time.sleep(n)
if __name__ == "__main__":
myFunction(2)
```
這將輸出執行函數`myFunction()`所花費的時間。 很酷的事情是,通過添加一行代碼`@measure_time`,我們現在可以測量程序執行時間。

**用例:Web 應用程序**
讓我們以 Web 應用程序的使用案例為例。 在 Flask 中構建 Web 應用程序時,您始終會編寫網址路由。
每個路由都是 Web 應用程序中的特定頁面。打開頁面`/about`可以調用`about_page()`方法。
```py
@app.route("/about")
def about_page():
return "Website about nachos"
```
在這種情況下,它使用`@`符號進行裝飾。
[下載示例和練習](https://gum.co/dcsp)
- 介紹
- 學習 python 的 7 個理由
- 為什么 Python 很棒
- 學習 Python
- 入門
- 執行 Python 腳本
- 變量
- 字符串
- 字符串替換
- 字符串連接
- 字符串查找
- 分割
- 隨機數
- 鍵盤輸入
- 控制結構
- if語句
- for循環
- while循環
- 數據與操作
- 函數
- 列表
- 列表操作
- 排序列表
- range函數
- 字典
- 讀取文件
- 寫入文件
- 嵌套循環
- 切片
- 多個返回值
- 作用域
- 時間和日期
- try except
- 如何使用pip和 pypi
- 面向對象
- 類
- 構造函數
- 獲取器和設置器
- 模塊
- 繼承
- 靜態方法
- 可迭代對象
- Python 類方法
- 多重繼承
- 高級
- 虛擬環境
- 枚舉
- Pickle
- 正則表達式
- JSON 和 python
- python 讀取 json 文件
- 裝飾器
- 網絡服務器
- 音頻
- 用 Python 播放聲音
- python 文字轉語音
- 將 MP3 轉換為 WAV
- 轉錄音頻
- Tkinter
- Tkinter
- Tkinter 按鈕
- Tkinter 菜單
- Tkinter 標簽
- Tkinter 圖片
- Tkinter 畫布
- Tkinter 復選框
- Tkinter 輸入框
- Tkinter 文件對話框
- Tkinter 框架
- Tkinter 列表框
- Tkinter 消息框
- Tkinter 單選按鈕
- Tkinter 刻度
- 繪圖
- Matplotlib 條形圖
- Matplotlib 折線圖
- Seaborn 分布圖
- Seaborn 繪圖
- Seaborn 箱形圖
- Seaborn 熱力圖
- Seaborn 直線圖
- Seaborn 成對圖
- Seaborn 調色板
- Seaborn Pandas
- Seaborn 散點圖
- Plotly
- PyQt
- PyQt
- 安裝 PyQt
- PyQt Hello World
- PyQt 按鈕
- PyQt QMessageBox
- PyQt 網格
- QLineEdit
- PyQT QPixmap
- PyQt 組合框
- QCheckBox
- QSlider
- 進度條
- PyQt 表格
- QVBoxLayout
- PyQt 樣式
- 編譯 PyQt 到 EXE
- QDial
- QCheckBox
- PyQt 單選按鈕
- PyQt 分組框
- PyQt 工具提示
- PyQt 工具箱
- PyQt 工具欄
- PyQt 菜單欄
- PyQt 標簽小部件
- PyQt 自動補全
- PyQt 列表框
- PyQt 輸入對話框
- Qt Designer Python
- 機器學習
- 數據科學
- 如何從機器學習和 AI 認真地起步
- 為什么要使用 Python 進行機器學習?
- 機器學習庫
- 什么是機器學習?
- 區分機器學習,深度學習和 AI?
- 機器學習
- 機器學習算法比較
- 為什么要使用 Scikit-Learn?
- 如何在 Python 中加載機器學習數據
- 機器學習分類器
- 機器學習回歸
- Python 中的多項式回歸
- 決策樹
- k 最近鄰
- 訓練測試拆分
- 人臉檢測
- 如何為 scikit-learn 機器學習準備數據
- Selenium
- Selenium 瀏覽器
- Selenium Cookie
- Selenium 執行 JavaScript
- Selenium 按 ID 查找元素
- Selenium 無頭 Firefox
- Selenium Firefox
- Selenium 獲取 HTML
- Selenium 鍵盤
- Selenium 最大化
- Selenium 截圖
- Selenium 向下滾動
- Selenium 切換到窗口
- Selenium 等待頁面加載
- Flask 教程
- Flask 教程:Hello World
- Flask 教程:模板
- Flask 教程:路由