Flask 函式庫- Python 教學| STEAM 教育學習網

文章推薦指數: 80 %
投票人數:10人

Flask 函式庫( 模組) 是一個輕量級的Web 應用框架,提供了包括路由( Routes )、樣板( templates ) 和權限( authorization) 等功能,只需要簡單的幾行程式碼, ... Flask函式庫 Flask函式庫(模組)是一個輕量級的Web應用框架,提供了包括路由(Routes)、樣板(templates)和權限(authorization)等功能,只需要簡單的幾行程式碼,就能輕鬆架設網站或建構網路服務,許多Python所實現的聊天機器人應用(例如LINEBOT),都會使用Flask來完成。

快速導覽: 安裝Flask函式庫 importFlask 建立第一個網頁服務 設定GET與POST方法 設定連線埠號port 變數規則 讀取參數 使用網頁樣板 安裝Flask函式庫 如果是使用Colab或Anaconda,預設已經安裝了requests函式庫,不用額外安裝,如果是本機環境,輸入下列指令,就能安裝requests函式庫(依據每個人的作業環境不同,可使用pip或pip3或pipenv)。

由於使用Flask會啟動本機環境網頁伺服器,若要使用GoogleColab必須搭配ngrok實作(參考:GoogleColab使用ngrok),建議第一次先使用AnacondaJupyter進行操作(參考:使用Anaconda)。

pipinstallFlask importFlask 要使用Flask必須先importFlask函式庫,或使用from的方式,單獨import特定的類型。

fromflaskimportFlask 建立第一個網頁服務 下方的程式碼執行後,會建立一個基本的網頁服務。

注意,如果使用Colab或AnacondaJupyter,同一個程式啟用網頁服務後,該程式裡其他片段的程式碼將會無法啟動(按下執行紐啟動)。

fromflaskimportFlask#載入Flask app=Flask(__name__)#建立app變數為Flask物件,__name__表示目前執行的程式 @app.route("/")#使用函式裝飾器,建立一個路由(Routes),可針對主網域/發出請求 defhome():#發出請求後會執行home()的函式 return"

helloworld

"#執行函式後會回傳特定的網頁內容 app.run()#執行 網頁服務建立後,在開發畫面裡可以看到已經啟動127.0.0.1:5000的網頁服務,其中127.0.0.1表示本機環境的伺服器ip,5000則是埠號port。

服務建立完成後,點擊產生的網址,或直接在瀏覽器的網址列輸入網址,就能看到網頁上出現helloworld的文字。

設定GET與POST方法 使用@app.route建立路由時,預設採用「GET」的方法,可透過method參數設定GET或POST。

如何簡單的區分GET和POST?GET方法可以透過網址進行溝通,以也就是透過網址列傳送所有的參數內容,POST方法則是將資料放在message-body進行傳送,無法單純透過網址列傳送。

下方的程式碼會啟用一個主網域為POST方法的網頁服務。

fromflaskimportFlask app=Flask(__name__) @app.route("/",methods=['POST']) defhome(): return"

helloworld

" app.run() 如果透過瀏覽器輸入網址,就會得到MethodNotAllowed的錯誤訊息。

如果改用requests函式庫的post方法,就能順利讀取並印出內容(參考:Requests函式庫)。

importrequests web=requests.post('http://127.0.0.1:5000/')#使用post方法 print(web.text)#讀取並印出text屬性 設定連線埠號port 使用app.run執行時,可以設定port參數來指定埠號port,或設定host為0.0.0.0就能採用本機實際分配到的IP作為網址,下方的程式執行後,會產生192.168.XXX.XXX:5555的網址。

fromflaskimportFlask app=Flask(__name__) @app.route("/") defhome(): return"

helloworld

" app.run(host="0.0.0.0",port=5555) 變數規則 使用@app.route可以指定特定的網址路徑,當使用者針對特定的網址發送請求後,就會執行對應的行為,下方的程式碼執行後,開啟三個網址會出現三種不同的結果。

fromflaskimportFlask app=Flask(__name__) @app.route("/") defhome(): return"

helloworld

" @app.route("/ok") defok(): return"

ok

" @app.route("/yes") defyes(): return"

yes

" app.run() 如果要讓程式更有彈性,則需要加入「變數」輔助,下方的程式執行後,就會在網頁中顯示根目錄後方的文字。

fromflaskimportFlask app=Flask(__name__) @app.route("/") defhome(): return"

helloworld

" @app.route("/")#加入讀取網址 defok(msg):#加入參數 returnf"

{msg}

"#使用變數 app.run() 在設定變數時,可以使用Flask提供的轉換器功能,指定內容的類型,Flask提供了五種轉換方式: 類型 說明 string 預設值,表示不包含斜線的文字。

int 正整數。

float 正浮點數。

path 路徑,類似string,但可以包含斜線。

uuid UUID字串。

下方的程式執行後,會在網頁顯示根目錄後方的網址內容。

fromflaskimportFlask app=Flask(__name__) @app.route("/") defhome(): return"

helloworld

" @app.route("/")#加入path:轉換成「路徑」的類型 defok(msg): returnf"

{msg}

" app.run() 讀取參數 實作網頁應用時,常常會使用網址的參數(GET)或message-body(POST)進行訊息的溝通,透過Flask提供的request方法,就能讀取傳遞的參數內容。

當服務使用GET方法時,request.args會將網址的參數讀取為tuple格式,tuple第一個項目為參數,第二個項目為值。

網址參數由網址後方加上?開始,不同參數以&區隔,例如127.0.0.1:5000?name=oxxo&age=18,就具有name和age兩個參數。

fromflaskimportFlask,request#載入了request app=Flask(__name__) @app.route("/") defhome(): print(request.args)#使用request.args return"

helloworld

" app.run() 當服務使用POST方法時,request.form會將message-body讀取為tuple格式,tuple第一個項目為參數,第二個項目為值。

fromflaskimportFlask,request app=Flask(__name__) @app.route("/",methods=['POST']) defhome(): print(request.form)#使用request.form return"

helloworld

" app.run() 當另外一組程式發送POST方法的請求時,就可以從後台看到執行的結果。

importrequests data={'name':'oxxo','age':'18'} web=requests.post('http://127.0.0.1:5000/',data=data)#發送POST請求 print(web.text) 不論是使用request.args或request.form,都能繼續透過的get方法取得指定參數的值,下方的程式會取得name和age的值,接著將其顯示在網頁中。

fromflaskimportFlask,request,render_template app=Flask(__name__) @app.route('/') defhome(): name=request.args.get('name') returnrender_template('test.html',name=name) app.run() 使用網頁樣板 呼叫Flask所建立的網頁服務後,除了可以在網頁上顯示特定的文字,只要額外載入render_template方法,就能顯示位於同一層的templates文件夾裡的網頁樣板,下方為一個基本的網頁樣板,可以讀取並顯示name參數的內容(使用Jinja2樣板語法)。

test {%ifname%}

Hello{{name}}!

{%else%}

Hello,World!

{%endif%} 網頁樣板完成後,執行下方的程式,只要網址具有name的參數,就會透過網頁樣板顯示在網頁中。

fromflaskimportFlask,request,render_template#載入render_template app=Flask(__name__) @app.route('/') defhome(): name=request.args.get('name') returnrender_template('test.html',name=name)#使用網頁樣板,並傳入參數 app.run() 意見回饋 如果有任何建議或問題,可傳送「意見表單」給我,謝謝~ Python教學 基本介紹 Python學習導讀 關於Python 使用GoogleColab 使用Anaconda 使用Python虛擬環境 Python範例集錦 資料型別 變數variable 變數(全域、區域) 數字number 文字與字串string 文字與字串(常用方法) 文字與字串(格式化) 串列list 串列(常用方法) 元組/數組tuple 字典dictionary 集合set 語法觀念 縮排和註解 運算子operator 邏輯判斷(if、elif、else) 邏輯判斷(and和or) 重複迴圈(for、while) 例外處理(try、except) 生成式comprehension 物件類別class 物件繼承inheritance 匯入模組import 函式操作 函式function 匿名函式lambda 遞迴recursion 產生器generator 裝飾器decorator 閉包closure 內建函式/方法 輸入與輸出 數學計算 字串操作與轉換 迭代物件轉換 迭代物件操作 檔案讀寫(open) eval()與exec() 標準函式庫/模組 隨機數random 數學math 數學統計函式statistics 時間與日期datetime 時間處理time 日曆calendar 使用正規表達式re 檔案操作os 查找匹配檔案glob 壓縮檔案zipfile 高階檔案操作shutil 高效迭代器itertools 容器資料型態collections CSV檔案操作 JSON檔案操作 concurrent.futures 網路爬蟲 Python網路爬蟲導讀 關於網路爬蟲 破解反爬蟲的方法 Requests函式庫 BeautifulSoup函式庫 Selenium函式庫 爬取PTT文章標題 自動下載PTT正妹圖片 同時下載多張圖片 爬取空氣品質指標(AQI) 爬取氣象預報 爬取現在天氣 LINENotify雷達回波圖 LINENotify即時地震資訊 爬取臺灣銀行牌告匯率 爬取Yahoo股市即時股價 爬取LINETODAY留言 批次下載Pinterest圖片 登入Mobile01截圖下載 Twitter自動上傳圖文 網頁服務與應用 Flask函式庫 使用ngrok服務 GoogleCloudFunctions 串接Gmail寄送電子郵件 讀取Google試算表 寫入Google試算表 發送LINENotify通知 LINEBOT教學 LINEBOT教學導讀 建立LINEChannel 設定Colab開發環境 建立並串接Webhook 解析LINE的訊息 自動回覆訊息 主動推播訊息 建立圖文選單 切換圖文選單 發送樣板訊息 發送FlexMessage 使用Requests傳送訊息 使用LINEURLScheme 氣象機器人(1) 氣象機器人(2) 氣象機器人(3) 氣象機器人(4) OpenCV教學 OpenCV教學導讀 OpenCV函式庫 開啟並顯示圖片 寫入並儲存圖片 讀取並播放影片 寫入並儲存影片 取得影像資訊 旋轉/翻轉/改變尺寸 影像的幾何變形 影像的色彩轉換 繪製各種形狀 影像加入文字 剪裁影像 調整對比和亮度 負片效果 影像模糊化 影像的疊加與相減 二值化黑白影像 影像的侵蝕與膨脹 影像邊緣偵測 魔術棒填充顏色 影像遮罩 邊緣羽化效果 馬賽克效果 子母畫面影片 萬花筒影片效果 多畫面延遲播放影片 搞笑全景影片合成效果 凸透鏡效果(魚眼效果) 倒數計時自動拍照效果 線性漸層填色 合成半透明圖片 將指定的顏色變透明 處理gif動畫 影片轉透明gif動畫 辨識QRCode和BarCode 掃描QRCode切換效果 偵測滑鼠事件 滑鼠選取自動馬賽克 即時在影片中繪圖 偵測鍵盤行為 加入滑桿(Trackbar) AI影像辨識教學 AI影像辨識教學導讀 OpenCV人臉偵測 OpenCV人臉馬賽克 OpenCV五官偵測 OpenCV汽車偵測 OpenCV行人偵測 OpenCV辨識不同人臉 OpenCV單物件追蹤 OpenCV多物件追蹤 OpenCV抓取特定顏色 OpenCV追蹤並標記顏色 情緒辨識與年齡偵測 辨識微笑,拍照儲存 使用Mediapipe Mediapipe人臉偵測 Mediapipe人臉網格 Mediapipe手掌偵測 Mediapipe姿勢偵測 Mediapipe全身偵測 Mediapipe物體偵測 Mediapipe人物去背 Mediapipe手勢辨識 辨識比中指,自動馬賽克 用手指在影片中畫圖 手指擦除鏡子霧氣效果 即時合成搞笑橘子臉 Jupyter安裝Tensorflow 使用TeachableMachine 辨識剪刀、石頭、布 辨識是否戴口罩 辨識手寫數字 NumPy教學 NumPy教學導讀 NumPy函式庫 資料型態 建立陣列 讀取陣列 迭代陣列 陣列項目賦值 修改陣列形狀 修改陣列項目 填充陣列 分割陣列 合併陣列 陣列排序 廣播 搜尋陣列項目 算數計算 數學函式 隨機數 字串操作處理 matplotlib圖表 matplotlib教學導讀 matplotlib函式庫 Figure和Axes Figure參數設定 建立多個子圖表 設定圖表標籤 設定座標軸位置 設定座標軸刻度文字 資料文字標記 加入顏色對照表 使用極座標系統 使用3D圖表 圖表顯示中文 下載儲存圖表 顯示圖片 製作圖表動畫 (圖表)折線圖 (圖表)散布圖 (圖表)長條圖 (圖表)圓餅圖 (圖表)甜甜圈圖 (圖表)等高線圖 (圖表)階梯折線圖 (圖表)堆疊折線圖 (圖表)堆疊長條圖 (圖表)極座標長條圖 (圖表)極座標散布圖 (圖表)3D柱狀長條圖 (圖表)3D散布圖 Tkinter設計介面 Tkinter教學導讀 建立Tkinter視窗 Label標籤 Button按鈕 Radiobutton單選按鈕 Checkbutton複選按鈕 Entry單行輸入框 Text多行輸入框 Listbox列表選擇框 OptionMenu下拉選單 Scale數值調整滑桿 Spinbox數值調整元件 Frame框架 LabelFrame標籤框架 Scrollbar滾動條 Canvas畫布 Menu選單 Messagebox訊息提示框 Photoimage顯示圖片 ttk.Progressbar進度條 ttk.Combobox下拉選單 Pack基本版面佈局 Grid格狀版面佈局 Place位置版面佈局 範例-Label製作時鐘 範例-點擊按鈕開檔案 範例-開啟多個檔案 範例-開啟並壓縮檔案 範例-開啟並顯示圖片 範例-調整圖片亮度對比 範例-簡單計算機 範例-發送LINENotify PyQt5設計介面 PyQt5教學導讀 PyQt5函式庫 使用Qtdesigner 建立PyQt5視窗 QLabel標籤 QPushButton按鈕 QRadioButton單選按鈕 QCheckBox複選按鈕 QGraphicsView顯示圖片 QLineEdit單行輸入框 QTextEdit多行輸入框 QListWidget列表選擇框 QComboBox下拉選單 QSpinBox數值調整元件 QTimeEdit時間調整元件 QDateEdit日期調整元件 QSlider數值調整滑桿 QProgressBar進度條 QFileDialog選擇檔案視窗 QMessageBox對話視窗 QInputDialog輸入視窗 QMenuBar視窗選單 QTimer定時器 QWebEngineView網頁 Layout佈局(垂直水平) Layout佈局(Grid網格) Layout佈局(Form表單) 影音處理範例 批次圖片轉檔 批次調整圖片尺寸 調整圖片亮度和對比 裁切與旋轉圖片 拼接多張圖片 圖片加上logo浮水印 圖片加上文字浮水印 圖片馬賽克效果 圖片模糊化 圖片銳利化 讀取與修改圖片Exif 圖片轉文字(OCR) 讀取聲音資訊、輸出聲音 聲音剪輯與串接 聲音音量調整 聲音混合與反轉 改變聲音速度 播放聲音 麥克風錄音 顯示聲波圖形 影片轉檔 取出影片聲音或加入聲音 影片剪輯與合併 影片混合與排列顯示 改變影片尺寸、旋轉翻轉 調整影片速度、倒轉影片 調整影片亮度/對比/顏色 影片轉gif動畫 影片中加入文字 影片自動加上字幕 影片截圖、圖片轉影片 實際應用範例 下載Youtube影片 下載Youtube清單影片 定時自動螢幕截圖 LINENotify傳送螢幕截圖 批次重新命名檔案 產生QRCode 產生BarCode 讀取PDF內容 PDF拆分/合併/插入/刪除 讀取EXCEL內容 寫入資料到EXCEL CSV寫入EXCEL 製作MacOSapp 基礎範例 攝氏/華氏轉換 公分/英吋換算 判斷平年與閏年 找出不重複字元 找出中間的字元 大樂透電腦選號 下載進度條 星號金字塔 數字金字塔 猜數字(猜大猜小) 猜數字(幾A幾B) 簡單時鐘(世界時間) 計算BMI數值 計算年紀(歲、月、天) 產生身分證字號(隨機) 檢查身分證字號 羅馬數字轉換 數學範例 兩個數字的四則運算 計算多個數字的總和 費波那契數列 九九乘法表 質因數分解 快速找出質數 最小公倍數(多個數字) 最大公因數(多個數字) ZeroJudge解答 關於ZeroJudge a001:哈囉 a002:簡易加法 a003:兩光法師占卜術 a004:文文的求婚 a005:Eva的回家作業 a006:一元二次方程式 a009:解碼器 a010:因數分解 a013:羅馬數字 a015:矩陣的翻轉 a017:五則運算 a020:身分證檢驗 a021:大數運算 a022:迴文 a024:最大公因數(GCD) a034:二進位制轉換 a038:數字翻轉 a040:阿姆斯壯數 a042:平面圓形切割 a044:空間切割 a053:Sagit's計分程式 a054:電話客服中心 a058:MOD3 a059:完全平方和 a065:提款卡密碼 a095:麥哲倫的陰謀 a104:排序 a147:Printitall a148:YouCannotPass?! a149:乘乘樂 a215:明明愛數數 a216:數數愛明明 a224:明明愛明明 a225:明明愛排列 a244:新手訓練~for+if a248:新手訓練~陣列應用 a263:日期差幾天 a271:彩色蘿蔔 a291:nAnBproblem a410:解方程 a414:位元運算之進位篇 a417:螺旋矩陣 a524:手機之謎 a528:大數排序 a647:投資專家 a693:吞食天地 a738:最大公約數 a746:畫蛇添足 a799:正值國 a915:二維點排序 b265:Conformity b294:經濟大恐荒 b367:翻轉世界 b374:求眾數 b511:換銅板 b558:求數列第n項 e267:GroupReverse d073:分組報告 d294:算算算Easy d485:我愛偶數 d827:買鉛筆


請為這篇文章評分?