搜尋

發送 LINE Notify ( 文字、表情、圖片 )

這篇教學會使用 PyQt6 設計一個操作介面,在介面中可以輸入文字、貼圖代號以及選擇電腦中的檔案,將這些資料透過 LINE Notify 發送到指定的帳號或群組裡。

快速導覽:

PyQt6 教學 - 發送 LINE Notify ( 文字、表情、圖片 )

預計畫面和功能

介面裡會包含「輸入文字的欄位」、「傳送表情貼圖的號碼」以及「開啟圖片」的功能,預計完成的畫面如下:

PyQt6 教學 - 發送 LINE Notify ( 文字、表情、圖片 ) - 預計畫面和功能

安裝 Requests 函式庫

發送 LINE Notify 需要透過三方函式庫 Requests 函式庫,如果是使用 Colab 或 Anaconda,預設已經安裝了 requests 函式庫,不用額外安裝,如果是本機環境,輸入下列指令,就能安裝 requests 函式庫 ( 依據每個人的作業環境不同,可使用 pip 或 pip3 或 pipenv,更多參考:Requests 函式庫 )。

pip install requests

申請 LINE Notify Token

參考「發送 LINE Notify 通知」教學文章,登入 LINE Notify 網站並發行「權杖」( token )。

LINE Notify:https://notify-bot.line.me/

完整程式碼

因為 LINE Notify 可以傳送文字、表情貼圖和圖片,所以可以設計「輸入欄位」以及「開啟檔案」的功能,實作出一個能夠傳送 LINE Notify 訊息的介面,程式邏輯設計的重點如下:

  • 需要有傳送文字的欄位,如果沒有文字內容,預設會變成「一個空白」( 必須要有一個空白才能傳送文字、表情或圖片 )。
  • 因為表情貼圖和圖片只能「擇一傳送」,因此可以使用「勾選方塊」設計出「切換」功能。
  • 如果要傳送圖片,可以透過按鈕開啟檔案選取視窗,取得要傳送的圖片路徑,再透過讀取檔案的方式傳送二進位圖片。

詳細說明寫在程式碼中:

from PyQt6 import QtWidgets
import sys
import requests

app = QtWidgets.QApplication(sys.argv)

Form = QtWidgets.QWidget()
Form.setWindowTitle('oxxo.studio')
Form.resize(400, 400)

# 建立要傳送的變數,預設都是空值
text = ''
img_url = ''
package_id = ''
sticker_id = ''
token = ''
package_id_temp = ''
sticker_id_temp = ''
img_url_temp = ''

# 取得要傳送的文字
def f1():
    global text
    text = input.toPlainText()     # 修改 text 變數內容為輸入欄位裡文字

label_1 = QtWidgets.QLabel(Form)   # 在 Form 裡加入標籤
label_1.setText('傳送文字')         # 設定標籤文字
label_1.setGeometry(20,5,100,40)

input = QtWidgets.QTextEdit(Form)  # QTextEdit 多行輸入框
input.setGeometry(20,40,360,150)
input.setLineWrapMode(input.LineWrapMode.NoWrap) # 設定不要自動換行,除非遇到換行符號
input.textChanged.connect(f1)      # 內容改變時執行 f1 函式

# 勾選傳送貼圖時要做的動作
def sticker():
    global package_id, sticker_id, img_url, package_id_temp, sticker_id_temp, img_url_temp
    # 如果勾選
    if cb.isChecked():
        img_url_temp = img_url         # 將圖片網址存到暫存變數裡
        img_url = ''                   # 清空圖片網址
        package_id = package_id_temp   # 讀取暫存變數的 package ID
        sticker_id = sticker_id_temp   # 讀取暫存變數的 Sticker ID
        label_p.setDisabled(False)     # 啟用表情區域的標籤
        box_p.setDisabled(False)       # 啟用表情區域的輸入欄位
        label_s.setDisabled(False)     # 啟用表情區域的標籤
        box_s.setDisabled(False)       # 啟用表情區域的輸入欄位
        label_img.setDisabled(True)    # 停用圖片區域的標籤
        btn_img.setDisabled(True)      # 停用圖片區域的按鈕
        input_img.setDisabled(True)    # 停用圖片區域的輸入欄位
    else:
        img_url = img_url_temp         # 讀取暫存變數的圖片網址
        package_id_temp = package_id   # 將 package ID 存到暫存變數裡
        sticker_id_temp = sticker_id   # 將 Sticker ID 存到暫存變數裡
        package_id = ''                # 清空 package_id
        sticker_id = ''                # 清空 sticker_id
        label_p.setDisabled(True)      # 停用表情區域的標籤
        box_p.setDisabled(True)        # 停用表情區域的輸入欄位
        label_s.setDisabled(True)      # 停用表情區域的標籤
        box_s.setDisabled(True)        # 停用表情區域的輸入欄位
        label_img.setDisabled(False)   # 啟用圖片區域的標籤
        btn_img.setDisabled(False)     # 啟用圖片區域的按鈕
        input_img.setDisabled(False)   # 啟用圖片區域的輸入欄位

# 按下送出按鈕時,要發送 LINe Notify 的函式
def sendLineNotify(msg='', token='', img_url='', package_id='', sticker_id=''):
    # 如果 msg 為空,將 msg 改成一個空白 ( 必須 )
    if msg == '':
        msg = ' '
    # 如果沒有 token,就不執行傳送命令
    if token != '':
        url = 'https://notify-api.line.me/api/notify'
        token = token
        headers = {
        'Authorization': 'Bearer ' + token
        }
        # 如果具有 package ID 和 Sticker ID
        if package_id != '' and sticker_id != '':
            # 傳送表情貼圖
            data = {
                'message':msg,
                'stickerPackageId':package_id,
                'stickerId':sticker_id
            }
            result = requests.post(url, headers=headers, data=data)
        else:
            # 如果沒有圖片來源網址
            if img_url == '':
                # 傳送文字
                data = {
                    'message':msg
                }
                result = requests.post(url, headers=headers, data=data)
            else:
                data = {
                    'message':msg
                }
                # 傳送夾帶二進位圖片的內容
                image = open(img_url, 'rb')
                imageFile = {'imageFile' : image}
                result = requests.post(url, headers=headers, data=data, files=imageFile)
        print(result)  # 印出傳送結果,200 表示傳送成功

# 輸入表情 ID 的函式
def f2():
    global package_id, sticker_id
    package_id = box_p.text()        # 修改 package_id 變數內容為輸入欄位裡文字
    sticker_id = box_s.text()        # 修改 sticker_id 變數內容為輸入欄位裡文字

cb = QtWidgets.QCheckBox(Form)       # 加入複選按鈕
cb.move(15, 200)
cb.setText('傳送表情')
cb.clicked.connect(sticker)          # 如果勾選,執行 sticker()

label_help = QtWidgets.QLabel(Form)   # 超連結連到 LINE 表情網站
label_help.setText('( <a href="https://developers.line.biz/en/docs/messaging-api/sticker-list/#specify-sticker-in-message-object">表情清單</a> )')        # 設定標籤文字
label_help.setGeometry(20,215,100,30)
label_help.setOpenExternalLinks(True) # 允許超連結

label_p = QtWidgets.QLabel(Form)      # 在 Form 裡加入標籤
label_p.setText('package ID')         # 設定標籤文字
label_p.setGeometry(120,190,100,40)
label_p.setDisabled(True)

box_p = QtWidgets.QLineEdit(Form)     # 加入單行輸入框
box_p.setGeometry(115,220,100,25)
box_p.setDisabled(True)
box_p.textChanged.connect(f2)         # 內容改變時執行 f2()

label_s = QtWidgets.QLabel(Form)      # 在 Form 裡加入標籤
label_s.setText('sticker ID')         # 設定標籤文字
label_s.setGeometry(230,190,100,40)
label_s.setDisabled(True)

box_s = QtWidgets.QLineEdit(Form)     # 加入單行輸入框
box_s.setGeometry(225,220,100,25)
box_s.setDisabled(True)
box_s.textChanged.connect(f2)         # 內容改變時執行 f2()

# 開啟圖片的韓式
def f3():
    filePath , filetype = QtWidgets.QFileDialog.getOpenFileName(filter='IMAGE(*.jpg)')
    input_img.setText(filePath)

# 圖片欄位改變時的函式
def f4():
    global img_url
    img_url = input_img.text()         # 修改 img_url 變數內容為輸入欄位裡文字

label_img= QtWidgets.QLabel(Form)       # 在 Form 裡加入標籤
label_img.setText('傳送圖片')            # 設定標籤文字
label_img.setGeometry(20,255,100,30)

btn_img = QtWidgets.QPushButton(Form)   # 在 Form 中加入一個 QPushButton
btn_img.setText('開啟')                 # 按鈕文字
btn_img.setGeometry(15,280,60,30)
btn_img.clicked.connect(f3)             # 點擊按鈕時執行 f3()

input_img = QtWidgets.QLineEdit(Form)   # 建立單行輸入框
input_img.setGeometry(85,283,295,25)    # 設定位置和尺寸
input_img.textChanged.connect(f4)       # 輸入欄位改變時執行 f4()

# token 欄位內容改變時的函式
def f_token():
    global token
    token = input_token.text()          # 修改 token 變數內容為輸入欄位裡文字

label_token= QtWidgets.QLabel(Form)      # 在 Form 裡加入標籤
label_token.setText('LINE Notify Token') # 設定標籤文字
label_token.setGeometry(20,320,200,30)

input_token = QtWidgets.QLineEdit(Form)   # 建立單行輸入框
input_token.setGeometry(15,350,295,25)    # 設定位置和尺寸
input_token.textChanged.connect(f_token)  # 輸入欄位改變時執行 f_token()

btn_send = QtWidgets.QPushButton(Form)  # 在 Form 中加入一個 QPushButton
btn_send.setText('送出')                 # 按鈕文字
btn_send.setGeometry(320,320,60,60)
btn_send.setStyleSheet('font-size:20px;')
# 點擊按鈕時執行 sendLineNotify()
btn_send.clicked.connect(lambda:sendLineNotify(text, token, img_url, package_id, sticker_id))

Form.show()
sys.exit(app.exec())

class 寫法:

from PyQt6 import QtWidgets
import sys
import requests

class MyWidget(QtWidgets.QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle('oxxo.studio')
        self.resize(400, 400)
        # 建立要傳送的變數,預設都是空值
        self.text = ''
        self.img_url = ''
        self.package_id = ''
        self.sticker_id = ''
        self.token = ''
        self.package_id_temp = ''
        self.sticker_id_temp = ''
        self.img_url_temp = ''
        self.ui()

    def ui(self):
        self.label_1 = QtWidgets.QLabel(self)   # 在 Form 裡加入標籤
        self.label_1.setText('傳送文字')         # 設定標籤文字
        self.label_1.setGeometry(20,5,100,40)

        self.input = QtWidgets.QTextEdit(self)  # QTextEdit 多行輸入框
        self.input.setGeometry(20,40,360,150)
        self.input.setLineWrapMode(self.input.LineWrapMode.NoWrap) # 設定不要自動換行,除非遇到換行符號
        self.input.textChanged.connect(self.f1)      # 內容改變時執行 f1 函式

        self.cb = QtWidgets.QCheckBox(self)       # 加入複選按鈕
        self.cb.move(15, 200)
        self.cb.setText('傳送表情')
        self.cb.clicked.connect(self.sticker)          # 如果勾選,執行 sticker()

        self.label_help = QtWidgets.QLabel(self)   # 超連結連到 LINE 表情網站
        self.label_help.setText('( <a href="https://developers.line.biz/en/docs/messaging-api/sticker-list/#specify-sticker-in-message-object">表情清單</a> )')        # 設定標籤文字
        self.label_help.setGeometry(20,215,100,30)
        self.label_help.setOpenExternalLinks(True) # 允許超連結

        self.label_p = QtWidgets.QLabel(self)      # 在 Form 裡加入標籤
        self.label_p.setText('package ID')         # 設定標籤文字
        self.label_p.setGeometry(120,190,100,40)
        self.label_p.setDisabled(True)

        self.box_p = QtWidgets.QLineEdit(self)     # 加入單行輸入框
        self.box_p.setGeometry(115,220,100,25)
        self.box_p.setDisabled(True)
        self.box_p.textChanged.connect(self.f2)         # 內容改變時執行 f2()

        self.label_s = QtWidgets.QLabel(self)      # 在 Form 裡加入標籤
        self.label_s.setText('sticker ID')         # 設定標籤文字
        self.label_s.setGeometry(230,190,100,40)
        self.label_s.setDisabled(True)

        self.box_s = QtWidgets.QLineEdit(self)     # 加入單行輸入框
        self.box_s.setGeometry(225,220,100,25)
        self.box_s.setDisabled(True)
        self.box_s.textChanged.connect(self.f2)         # 內容改變時執行 f2()

        self.label_img= QtWidgets.QLabel(self)       # 在 Form 裡加入標籤
        self.label_img.setText('傳送圖片')            # 設定標籤文字
        self.label_img.setGeometry(20,255,100,30)

        self.btn_img = QtWidgets.QPushButton(self)   # 在 Form 中加入一個 QPushButton
        self.btn_img.setText('開啟')                 # 按鈕文字
        self.btn_img.setGeometry(15,280,60,30)
        self.btn_img.clicked.connect(self.f3)             # 點擊按鈕時執行 f3()

        self.input_img = QtWidgets.QLineEdit(self)   # 建立單行輸入框
        self.input_img.setGeometry(85,283,295,25)    # 設定位置和尺寸
        self.input_img.textChanged.connect(self.f4)       # 輸入欄位改變時執行 f4()

        self.label_token= QtWidgets.QLabel(self)      # 在 Form 裡加入標籤
        self.label_token.setText('LINE Notify Token') # 設定標籤文字
        self.label_token.setGeometry(20,320,200,30)

        self.input_token = QtWidgets.QLineEdit(self)   # 建立單行輸入框
        self.input_token.setGeometry(15,350,295,25)    # 設定位置和尺寸
        self.input_token.textChanged.connect(self.f_token)  # 輸入欄位改變時執行 f_token()

        self.btn_send = QtWidgets.QPushButton(self)  # 在 Form 中加入一個 QPushButton
        self.btn_send.setText('送出')                 # 按鈕文字
        self.btn_send.setGeometry(320,320,60,60)
        self.btn_send.setStyleSheet('font-size:20px;')
        # 點擊按鈕時執行 sendLineNotify()
        self.btn_send.clicked.connect(lambda:self.sendLineNotify(self.text, self.token, self.img_url, self.package_id, self.sticker_id))

    # 取得要傳送的文字
    def f1(self):
        self.text = self.input.toPlainText()     # 修改 text 變數內容為輸入欄位裡文字

    # 開啟圖片的韓式
    def f3(self):
        filePath , filetype = QtWidgets.QFileDialog.getOpenFileName(filter='IMAGE(*.jpg)')
        self.input_img.setText(filePath)

    # 輸入表情 ID 的函式
    def f2(self):
        self.package_id = self.box_p.text()        # 修改 package_id 變數內容為輸入欄位裡文字
        self.sticker_id = self.box_s.text()        # 修改 sticker_id 變數內容為輸入欄位裡文字

    # 圖片欄位改變時的函式
    def f4(self):
        self.img_url = self.input_img.text()         # 修改 img_url 變數內容為輸入欄位裡文字

    # token 欄位內容改變時的函式
    def f_token(self):
        self.token = self.input_token.text()          # 修改 token 變數內容為輸入欄位裡文字

    # 勾選傳送貼圖時要做的動作
    def sticker(self):
        # 如果勾選
        if self.cb.isChecked():
            self.img_url_temp = self.img_url         # 將圖片網址存到暫存變數裡
            self.img_url = ''                   # 清空圖片網址
            self.package_id = self.package_id_temp   # 讀取暫存變數的 package ID
            self.sticker_id = self.sticker_id_temp   # 讀取暫存變數的 Sticker ID
            self.label_p.setDisabled(False)     # 啟用表情區域的標籤
            self.box_p.setDisabled(False)       # 啟用表情區域的輸入欄位
            self.label_s.setDisabled(False)     # 啟用表情區域的標籤
            self.box_s.setDisabled(False)       # 啟用表情區域的輸入欄位
            self.label_img.setDisabled(True)    # 停用圖片區域的標籤
            self.btn_img.setDisabled(True)      # 停用圖片區域的按鈕
            self.input_img.setDisabled(True)    # 停用圖片區域的輸入欄位
        else:
            self.img_url = self.img_url_temp         # 讀取暫存變數的圖片網址
            self.package_id_temp = self.package_id   # 將 package ID 存到暫存變數裡
            self.sticker_id_temp = self.sticker_id   # 將 Sticker ID 存到暫存變數裡
            self.package_id = ''                # 清空 package_id
            self.sticker_id = ''                # 清空 sticker_id
            self.label_p.setDisabled(True)      # 停用表情區域的標籤
            self.box_p.setDisabled(True)        # 停用表情區域的輸入欄位
            self.label_s.setDisabled(True)      # 停用表情區域的標籤
            self.box_s.setDisabled(True)        # 停用表情區域的輸入欄位
            self.label_img.setDisabled(False)   # 啟用圖片區域的標籤
            self.btn_img.setDisabled(False)     # 啟用圖片區域的按鈕
            self.input_img.setDisabled(False)   # 啟用圖片區域的輸入欄位

    # 按下送出按鈕時,要發送 LINe Notify 的函式
    def sendLineNotify(self, msg='', token='', img_url='', package_id='', sticker_id=''):
        # 如果 msg 為空,將 msg 改成一個空白 ( 必須 )
        if msg == '':
            msg = ' '
        # 如果沒有 token,就不執行傳送命令
        if token != '':
            url = 'https://notify-api.line.me/api/notify'
            token = token
            headers = {
            'Authorization': 'Bearer ' + token
            }
            # 如果具有 package ID 和 Sticker ID
            if package_id != '' and sticker_id != '':
                # 傳送表情貼圖
                data = {
                    'message':msg,
                    'stickerPackageId':package_id,
                    'stickerId':sticker_id
                }
                result = requests.post(url, headers=headers, data=data)
            else:
                # 如果沒有圖片來源網址
                if img_url == '':
                    # 傳送文字
                    data = {
                        'message':msg
                    }
                    result = requests.post(url, headers=headers, data=data)
                else:
                    data = {
                        'message':msg
                    }
                    # 傳送夾帶二進位圖片的內容
                    image = open(img_url, 'rb')
                    imageFile = {'imageFile' : image}
                    result = requests.post(url, headers=headers, data=data, files=imageFile)
            print(result)  # 印出傳送結果,200 表示傳送成功

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    Form = MyWidget()
    Form.show()
    sys.exit(app.exec())

PyQt6 教學 - 發送 LINE Notify ( 文字、表情、圖片 )

意見回饋

如果有任何建議或問題,可傳送「意見表單」給我,謝謝~

Python 教學

基本介紹

Python 學習導讀 關於 Python 使用 Google Colab 使用 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 檔案操作 threading 多執行緒處理 concurrent.futures

網路爬蟲

Python 網路爬蟲導讀 關於網路爬蟲 破解反爬蟲的方法 Requests 函式庫 Beautiful Soup 函式庫 Selenium 函式庫 爬取 PTT 文章標題 自動下載 PTT 正妹圖片 同時下載多張圖片 同時下載多張寶可夢圖片 爬取 CCTV 即時影像 爬取統一發票號碼對獎 爬取空氣品質指標 ( AQI ) 爬取氣象預報 爬取現在天氣 LINE Notify 雷達回波圖 LINE Notify 即時地震資訊 爬取臺灣銀行牌告匯率 爬取 Yahoo 股市即時股價 爬取 LINE TODAY 留言 批次下載 Pinterest 圖片 登入 Mobile01 截圖下載 Twitter 自動上傳圖文

網頁服務與應用

Flask 函式庫 使用 ngrok 服務 Google Cloud Functions 串接 Gmail 寄送電子郵件 讀取 Google 試算表 寫入 Google 試算表 上傳 Google 雲端硬碟 發送 LINE Notify 通知 使用 Dialogflow Dialogflow + Webhook 伺服器串接 Dialogflow 串接 Firebase 資料庫 (1) 串接 Firebase 資料庫 (2) 串接 Firebase 資料庫 (3) 使用 OpenAI ChatGPT ChatGPT + Firebase

LINE BOT 教學

LINE BOT 教學導讀 ( 免程式 ) 建立 LINE 官方帳號 ( 免程式 ) 主動推播訊息 ( 免程式 ) 自動回覆訊息 ( 免程式 ) 建立圖文選單 ( 免程式 ) 基本訊息類型 建立 LINE Channel 設定 Colab 開發環境 建立並串接 Webhook 解析 LINE 的訊息 自動回覆訊息 主動推播訊息 建立圖文選單 切換圖文選單 發送樣板訊息 發送 Flex Message 使用 Requests 傳送訊息 使用 LINE URL Scheme 儲存使用者的圖片或影片 串接 Email 傳送圖片或影片 串接 Google 雲端硬碟 氣象機器人 (1) 氣象機器人 (2) 氣象機器人 (3) 氣象機器人 (4) 串接 Dialogflow (1) 串接 Dialogflow (2) 串接 Dialogflow (3) 串接 Dialogflow (4) 串接 OpenAI ChatGPT (1) 串接 OpenAI ChatGPT (2) 串接 OpenAI ChatGPT (3)

OpenCV 教學

OpenCV 教學導讀 OpenCV 函式庫 開啟並顯示圖片 寫入並儲存圖片 讀取並播放影片 寫入並儲存影片 取得影像資訊 旋轉/翻轉/改變尺寸 影像的幾何變形 影像的色彩轉換 繪製各種形狀 影像加入文字 剪裁影像 調整對比和亮度 負片效果 影像模糊化 影像的疊加與相減 二值化黑白影像 影像的侵蝕與膨脹 影像邊緣偵測 魔術棒填充顏色 影像遮罩 邊緣羽化效果 馬賽克效果 子母畫面影片 萬花筒影片效果 多畫面延遲播放影片 搞笑全景影片合成效果 凸透鏡效果 ( 魚眼效果 ) 倒數計時自動拍照效果 線性漸層填色 合成半透明圖片 將指定的顏色變透明 處理 gif 動畫 影片轉透明 gif 動畫 辨識 QRCode 和 BarCode 掃描 QRCode 切換效果 偵測滑鼠事件 滑鼠選取自動馬賽克 即時在影片中繪圖 偵測鍵盤行為 加入滑桿 ( Trackbar ) 拍照上傳 Google 雲端硬碟

AI 影像辨識教學

AI 影像辨識教學導讀 OpenCV 人臉偵測 OpenCV 人臉馬賽克 OpenCV 五官偵測 OpenCV 汽車偵測 OpenCV 行人偵測 OpenCV 辨識不同人臉 OpenCV 單物件追蹤 OpenCV 多物件追蹤 OpenCV 抓取特定顏色 OpenCV 追蹤並標記顏色 情緒辨識與年齡偵測 辨識微笑,拍照儲存 使用 Mediapipe ( 新 ) Mediapipe 人臉偵測 ( 新 ) Mediapipe 人臉特徵點偵測 ( 新 ) Mediapipe 手掌偵測 ( 新 ) 使用 Mediapipe ( 舊 ) Mediapipe 人臉偵測 ( 舊 ) Mediapipe 人臉網格 ( 舊 ) Mediapipe 手掌偵測 ( 舊 ) Mediapipe 姿勢偵測 Mediapipe 全身偵測 Mediapipe 物體偵測 Mediapipe 人物去背 Mediapipe 手勢辨識 辨識比中指,自動馬賽克 用手指在影片中畫圖 手指擦除鏡子霧氣效果 即時合成搞笑橘子臉 Jupyter 安裝 Tensorflow 使用 Teachable Machine 辨識剪刀、石頭、布 辨識是否戴口罩 辨識手寫數字

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 製作時鐘 範例 - 點擊按鈕開檔案 範例 - 開啟多個檔案 範例 - 開啟並壓縮檔案 範例 - 開啟並顯示圖片 範例 - 調整圖片亮度對比 範例 - 簡單計算機 範例 - 發送 LINE Notify

PyQt5 介面設計

PyQt5 教學導讀 PyQt5 函式庫 使用 Qt designer 建立 PyQt5 視窗 QLabel 標籤 QPushButton 按鈕 QRadioButton 單選按鈕 QCheckBox 複選按鈕 QGraphicsView 顯示圖片 QLineEdit 單行輸入框 QTextEdit 多行輸入框 QListWidget 列表選擇框 QComboBox 下拉選單 QSpinBox 數值調整元件 QTimeEdit 時間調整元件 QDateEdit 日期調整元件 QSlider 數值調整滑桿 QProgressBar 進度條 QFileDialog 選擇檔案視窗 QMessageBox 對話視窗 QInputDialog 輸入視窗 QMenuBar 視窗選單 QTimer 定時器 QThread 多執行緒 QtCore.pyqtSignal 信號傳遞 QtMultimedia 播放聲音 QPainter 繪圖 QPainter 繪圖 ( QPen ) QPainter 繪圖 ( 儲存圖片 ) QSS 樣式設定 QWebEngineView 網頁顯示 Layout 佈局 ( 垂直水平 ) Layout 佈局 ( Grid 網格 ) Layout 佈局 ( Form 表單 ) 偵測滑鼠事件 偵測鍵盤與快速鍵組合 偵測與控制視窗 視窗中開啟新視窗 顯示圖片的三種方法 顯示 Matplotlib 圖表 顯示 Pillow 圖片 顯示 OpenCV 圖片和影片 範例 - 世界時鐘 範例 - 簡單計算機 範例 - 儲存檔案為壓縮檔 範例 - 發送 LINE Notify 範例 - 電腦攝影機 範例 - 攝影機拍照錄影 範例 - 簡單錄音機 範例 - 小畫家 範例 - 開啟圖片轉檔儲存 範例 - 調整圖片亮度對比

PyQt6 介面設計

PyQt6 教學導讀 PyQt6 函式庫 PyQt6 和 PyQt5 的差異 建立 PyQt6 視窗 QLabel 標籤 QPushButton 按鈕 QRadioButton 單選按鈕 QCheckBox 複選按鈕 QGraphicsView 顯示圖片 QLineEdit 單行輸入框 QTextEdit 多行輸入框 QListWidget 列表選擇框 QComboBox 下拉選單 QSpinBox 數值調整元件 QTimeEdit 時間調整元件 QDateEdit 日期調整元件 QSlider 數值調整滑桿 QProgressBar 進度條 QFileDialog 選擇檔案視窗 QMessageBox 對話視窗 QInputDialog 輸入視窗 QMenuBar 視窗選單 QTimer 定時器 QThread 多執行緒 QtCore.pyqtSignal 信號傳遞 QtMultimedia 播放聲音 QPainter 繪圖 QPainter 繪圖 ( QPen ) QPainter 繪圖 ( 儲存圖片 ) QSS 樣式設定 QWebEngineView 網頁顯示 Layout 佈局 ( 垂直水平 ) Layout 佈局 ( Grid 網格 ) Layout 佈局 ( Form 表單 ) 偵測滑鼠事件 偵測鍵盤與快速鍵組合 偵測與控制視窗 視窗中開啟新視窗 顯示圖片的三種方法 顯示 Matplotlib 圖表 顯示 Pillow 圖片 顯示 OpenCV 圖片和影片 範例 - 世界時鐘 範例 - 簡單計算機 範例 - 儲存檔案為壓縮檔 範例 - 發送 LINE Notify 範例 - 電腦攝影機 範例 - 攝影機拍照錄影 範例 - 簡單錄音機 範例 - 小畫家 範例 - 開啟圖片轉檔儲存 範例 - 調整圖片亮度對比

影音處理範例

批次圖片轉檔 批次調整圖片尺寸 調整圖片亮度和對比 裁切與旋轉圖片 拼接多張圖片 圖片加上 logo 浮水印 圖片加上文字浮水印 圖片馬賽克效果 圖片模糊化 圖片銳利化 讀取與修改圖片 Exif 圖片轉文字 ( OCR ) 讀取聲音資訊、輸出聲音 聲音剪輯與串接 聲音音量調整 聲音混合與反轉 改變聲音速度 播放聲音 麥克風錄音 合成音符聲音 顯示聲波圖形 影片轉檔 取出影片聲音或加入聲音 影片剪輯與合併 影片混合與排列顯示 改變影片尺寸、旋轉翻轉 調整影片速度、倒轉影片 調整影片亮度/對比/顏色 影片轉 gif 動畫 影片中加入文字 影片自動加上字幕 影片截圖、圖片轉影片

實際應用範例

下載 Youtube 影片 下載 Youtube 清單影片 定時自動螢幕截圖 LINE Notify 傳送螢幕截圖 建立 MJPEG 即時影像串流 批次重新命名檔案 產生 QRCode 產生 BarCode 讀取 PDF 內容 PDF 拆分/合併/插入/刪除 讀取 EXCEL 內容 寫入資料到 EXCEL CSV 寫入 EXCEL 讀取電腦資訊 偵測電腦螢幕解析度 查詢電腦對內對外 IP 查詢網站 IP、ping IP 製作 MacOS app

基礎範例

電費試算 攝氏/華氏轉換 公分/英吋換算 判斷平年與閏年 找出不重複字元 找出中間的字元 去除中英文夾雜的空白 大樂透電腦選號 下載進度條 星號金字塔 數字金字塔 猜數字 ( 猜大猜小 ) 猜數字 ( 幾 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: Print it all a148: You Cannot Pass?! a149: 乘乘樂 a215: 明明愛數數 a216: 數數愛明明 a224: 明明愛明明 a225: 明明愛排列 a244: 新手訓練~for+if a248: 新手訓練~陣列應用 a263: 日期差幾天 a271: 彩色蘿蔔 a291: nAnB problem a410: 解方程 a414: 位元運算之進位篇 a417: 螺旋矩陣 a524: 手機之謎 a528: 大數排序 a647: 投資專家 a693: 吞食天地 a738: 最大公約數 a746: 畫蛇添足 a799: 正值國 a915: 二維點排序 b265: Conformity b294: 經濟大恐荒 b367: 翻轉世界 b374: 求眾數 b511: 換銅板 b558: 求數列第 n 項 e267: Group Reverse d073: 分組報告 d294: 算算算 Easy d485: 我愛偶數 d827: 買鉛筆