Python+Tkinter實(shí)現(xiàn)高顏值桌面便簽工具
概述:為什么我們需要一個桌面便簽工具
在快節(jié)奏的現(xiàn)代生活中,高效的任務(wù)管理成為提升生產(chǎn)力的關(guān)鍵。市面上的待辦事項應(yīng)用雖然功能豐富,但往往存在以下痛點(diǎn):
- 需要聯(lián)網(wǎng)使用,隱私性差
- 界面復(fù)雜,啟動緩慢
- 無法深度自定義功能
本文將帶你用Python的Tkinter庫開發(fā)一款輕量級桌面便簽工具,具備以下亮點(diǎn)功能:
- 日期分組管理
- 智能提醒系統(tǒng)
- 任務(wù)完成狀態(tài)追蹤
- 簡潔美觀的UI設(shè)計
- 本地化數(shù)據(jù)存儲
(開發(fā)環(huán)境:Python 3.8+,無需額外安裝庫)
核心功能實(shí)現(xiàn)詳解
1. 整體架構(gòu)設(shè)計
class TodoApp:
def __init__(self, root):
self.tasks_by_date = {} # 按日期分組的任務(wù)字典
self.group_states = {} # 分組展開狀態(tài)
self.create_widgets() # 初始化UI
self.load_tasks() # 加載本地任務(wù)
self.check_alarms_on_startup() # 啟動時檢查提醒
self.update_time() # 實(shí)時時鐘
2. 智能提醒系統(tǒng)實(shí)現(xiàn)
核心算法通過比較當(dāng)前時間與預(yù)設(shè)提醒時間實(shí)現(xiàn)精準(zhǔn)提醒:
def set_alarm_timer(self, alarm_time, alarm_message, task_text, add_time, date):
delay = (alarm_time - datetime.now()).total_seconds() * 1000
self.root.after(int(delay), lambda: self.show_alarm(...))
def check_alarms_on_startup(self):
# 啟動時檢查所有未完成任務(wù)的提醒時間
for date in self.tasks_by_date:
for task in self.tasks_by_date[date]:
if task[4] != "無" and not task[1]:
alarm_time = datetime.strptime(task[4], "%Y-%m-%d %H:%M:%S")
if alarm_time <= datetime.now():
self.show_alarm(...)
3. 任務(wù)狀態(tài)管理邏輯
當(dāng)用戶標(biāo)記任務(wù)完成時,系統(tǒng)會進(jìn)行時間校驗(yàn):
def update_completion_time(self, var, time_label, task_text, add_time, date):
if var.get(): # 如果標(biāo)記為完成
completion_time = datetime.now()
# 檢查提醒時間是否晚于完成時間
if alarm_time > completion_time:
var.set(False) # 取消完成狀態(tài)
messagebox.showinfo("提示", "提醒時間晚于完成時間...")
4. 數(shù)據(jù)持久化方案
采用CSV格式存儲任務(wù)數(shù)據(jù),每行包含:
任務(wù)內(nèi)容,完成狀態(tài),添加時間,完成時間,提醒時間,提醒信息
讀寫實(shí)現(xiàn):
def load_tasks(self):
if os.path.exists('tasks.csv'):
with open('tasks.csv', 'r', encoding='utf-8') as file:
reader = csv.reader(file)
for row in reader:
# 解析每行數(shù)據(jù)...
def save_tasks(self, silent=False):
with open('tasks.csv', 'w', encoding='utf-8', newline='') as file:
writer = csv.writer(file)
for date in self.tasks_by_date:
for task in self.tasks_by_date[date]:
writer.writerow(list(task))
UI設(shè)計技巧與優(yōu)化
1. 現(xiàn)代化界面布局
[界面結(jié)構(gòu)圖]
主界面結(jié)構(gòu):
- 頂部:標(biāo)題+實(shí)時時鐘
- 中部:輸入框+添加按鈕
- 底部:帶滾動條的任務(wù)顯示區(qū)域
2. 交互細(xì)節(jié)優(yōu)化
# 平滑滾動實(shí)現(xiàn)
def _on_mousewheel(self, event):
self.canvas.yview_scroll(int(-1*(event.delta/120)), "units")
# 分組折疊功能
def toggle_group(self, date, button):
self.group_states[date] = not self.group_states.get(date, True)
self.refresh_display()
3. 顏色方案
| 元素 | 顏色值 | 用途 |
|---|---|---|
| 背景色 | #f0f0f0 | 主窗口背景 |
| 任務(wù)卡片 | #fafafa | 任務(wù)項背景 |
| 完成文本 | #2E7D32 | 已完成任務(wù)文字 |
| 未完成文本 | #757575 | 未完成任務(wù)文字 |
功能擴(kuò)展思路
1.云同步功能
添加Dropbox/Google Drive API支持
實(shí)現(xiàn)多設(shè)備同步
2.分類標(biāo)簽系統(tǒng)
def add_tag(self, task_id, tag_name):
# 為任務(wù)添加彩色標(biāo)簽
pass
3.數(shù)據(jù)統(tǒng)計分析
- 使用matplotlib生成任務(wù)完成率圖表
- 導(dǎo)出周報/月報
4.快捷鍵支持
self.root.bind('<Control-n>', lambda e: self.add_task())
self.root.bind('<Control-s>', lambda e: self.save_tasks())
運(yùn)行效果




完整源碼獲取
import tkinter as tk
from tkinter import messagebox
import csv
import os
from datetime import datetime
class TodoApp:
def __init__(self, root):
self.root = root
self.root.title("桌面便簽工具")
self.root.geometry("390x600")
self.root.configure(bg="#f0f0f0")
self.tasks_by_date = {}
self.group_states = {}
self.create_widgets()
self.load_tasks()
self.check_alarms_on_startup()
self.update_time() # 啟動時間更新
def create_widgets(self):
# 標(biāo)題
title_label = tk.Label(self.root, text="待辦事項", font=("SimSun", 16, "bold"), bg="#f0f0f0", fg="#333333")
title_label.pack(pady=10)
# 輸入框架
input_frame = tk.Frame(self.root, bg="#f0f0f0")
input_frame.pack(pady=5)
# 當(dāng)前時間顯示
self.time_label = tk.Label(input_frame, text="", font=("SimSun", 12), bg="#f0f0f0", fg="#333333")
self.time_label.pack(pady=(0, 5))
# 輸入框
self.entry = tk.Entry(input_frame, width=40, font=("SimSun", 12), bd=2, relief="flat")
self.entry.pack(pady=(0, 5)) # 修改為垂直布局
self.entry.focus_set()
# 添加按鈕
add_button = tk.Button(input_frame, text="添加", command=self.add_task,
font=("SimSun", 10), bg="#4CAF50", fg="white", bd=0, padx=10, pady=5)
add_button.pack() # 放在輸入框下方
# 任務(wù)顯示框架
self.task_frame = tk.Frame(self.root, bg="#ffffff", bd=1, relief="solid")
self.task_frame.pack(pady=10, padx=10, fill=tk.BOTH, expand=True)
self.canvas = tk.Canvas(self.task_frame, bg="#ffffff", highlightthickness=0)
self.scrollbar = tk.Scrollbar(self.task_frame, orient="vertical", command=self.canvas.yview)
self.scrollbar.pack(side=tk.RIGHT, fill=tk.Y)
self.canvas.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)
self.canvas.configure(yscrollcommand=self.scrollbar.set)
self.inner_frame = tk.Frame(self.canvas, bg="#ffffff")
self.canvas.create_window((0, 0), window=self.inner_frame, anchor="nw")
self.inner_frame.bind("<Configure>", lambda e: self.canvas.configure(scrollregion=self.canvas.bbox("all")))
self.canvas.bind_all("<MouseWheel>", self._on_mousewheel)
def update_time(self):
"""更新當(dāng)前時間顯示"""
current_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
self.time_label.config(text=f"當(dāng)前時間: {current_time}")
self.root.after(1000, self.update_time) # 每秒更新一次
def _on_mousewheel(self, event):
self.canvas.yview_scroll(int(-1 * (event.delta / 120)), "units")
def toggle_group(self, date, button):
is_expanded = self.group_states.get(date, True)
self.group_states[date] = not is_expanded
button.config(text=f"{'▼' if not is_expanded else '?'} {date}")
self.refresh_display()
self.save_tasks(silent=True)
def update_completion_time(self, var, time_label, task_text, add_time, date):
alarm_time_str = "無"
alarm_message = "無"
for task in self.tasks_by_date[date]:
if task[0] == task_text and task[2] == add_time:
alarm_time_str = task[4]
alarm_message = task[5]
break
if var.get():
completion_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
if alarm_time_str != "無":
try:
alarm_time = datetime.strptime(alarm_time_str, "%Y-%m-%d %H:%M:%S")
completion_datetime = datetime.strptime(completion_time, "%Y-%m-%d %H:%M:%S")
if alarm_time > completion_datetime:
var.set(False)
messagebox.showinfo("提示", f"任務(wù) '{task_text}' 的提醒時間晚于完成時間,已取消完成狀態(tài)并保留提醒")
completion_time = "未完成"
time_label.config(text=f"添加時間: {add_time}\n完成時間: {completion_time}", fg="#757575")
for i, (t_text, _, a_time, _, at, am) in enumerate(self.tasks_by_date[date]):
if t_text == task_text and a_time == add_time:
self.tasks_by_date[date][i] = (task_text, False, add_time, completion_time, at, am)
self.set_alarm_timer(alarm_time, alarm_message, task_text, add_time, date)
break
self.save_tasks(silent=True)
self.refresh_display()
return
except ValueError:
pass
time_label.config(text=f"添加時間: {add_time}\n完成時間: {completion_time}", fg="#2E7D32")
for i, (t_text, _, a_time, _, at, am) in enumerate(self.tasks_by_date[date]):
if t_text == task_text and a_time == add_time:
self.tasks_by_date[date][i] = (task_text, True, add_time, completion_time, at, am)
break
else:
time_label.config(text=f"添加時間: {add_time}\n完成時間: 未完成", fg="#757575")
for i, (t_text, _, a_time, _, at, am) in enumerate(self.tasks_by_date[date]):
if t_text == task_text and a_time == add_time:
self.tasks_by_date[date][i] = (task_text, False, add_time, "未完成", at, am)
if alarm_time_str != "無":
try:
alarm_time = datetime.strptime(alarm_time_str, "%Y-%m-%d %H:%M:%S")
if alarm_time > datetime.now():
self.set_alarm_timer(alarm_time, alarm_message, task_text, add_time, date)
except ValueError:
pass
break
self.save_tasks(silent=True)
self.refresh_display()
def edit_task(self, task_text, add_time, date, label):
edit_window = tk.Toplevel(self.root)
edit_window.title("編輯任務(wù)")
edit_window.geometry("300x100")
edit_window.configure(bg="#f0f0f0")
tk.Label(edit_window, text="任務(wù)內(nèi)容:", bg="#f0f0f0").pack(pady=5)
entry = tk.Entry(edit_window, width=40, font=("SimSun", 11))
entry.pack(pady=5)
entry.insert(0, task_text)
def save_edit():
new_text = entry.get().strip()
if new_text:
for i, (t_text, completed, a_time, c_time, at, am) in enumerate(self.tasks_by_date[date]):
if t_text == task_text and a_time == add_time:
self.tasks_by_date[date][i] = (new_text, completed, a_time, c_time, at, am)
break
self.refresh_display()
self.save_tasks(silent=True)
edit_window.destroy()
else:
messagebox.showwarning("警告", "任務(wù)內(nèi)容不能為空!")
tk.Button(edit_window, text="保存", command=save_edit, bg="#4CAF50", fg="white", bd=0).pack(pady=5)
# 刪除功能2025.4.2已修改
def delete_task(self, task_text, add_time, date):
if messagebox.askyesno("確認(rèn)", "確定刪除此任務(wù)嗎?"):
for i, (t_text, _, a_time, _, _, _) in enumerate(self.tasks_by_date[date]):
if t_text == task_text and a_time == add_time:
del self.tasks_by_date[date][i]
break
if not self.tasks_by_date[date]:
del self.tasks_by_date[date]
del self.group_states[date]
self.refresh_display()
self.save_tasks(silent=True)
def add_task(self):
task_text = self.entry.get().strip()
if task_text:
add_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
date = add_time.split()[0]
if date not in self.tasks_by_date:
self.tasks_by_date[date] = []
self.group_states[date] = True
self.tasks_by_date[date].insert(0, (task_text, False, add_time, "未完成", "無", "無"))
self.refresh_display()
self.entry.delete(0, tk.END)
self.save_tasks(silent=True)
else:
messagebox.showwarning("警告", "請輸入任務(wù)內(nèi)容!")
def set_alarm(self, task_text, add_time, date):
alarm_window = tk.Toplevel(self.root)
alarm_window.title("設(shè)置提醒")
alarm_window.geometry("400x300")
alarm_window.configure(bg="#f0f0f0")
tk.Label(alarm_window, text="提醒日期 (格式: YYYYMMDD, 留空默認(rèn)當(dāng)天):", bg="#f0f0f0").pack(pady=5)
date_entry = tk.Entry(alarm_window, width=40, font=("SimSun", 11))
date_entry.pack(pady=5)
tk.Label(alarm_window, text="提醒時間 (格式: HHMMSS或HHMM, 無秒默認(rèn)為00):", bg="#f0f0f0").pack(pady=5)
time_entry = tk.Entry(alarm_window, width=40, font=("SimSun", 11))
time_entry.pack(pady=5)
tk.Label(alarm_window, text="提醒信息:", bg="#f0f0f0").pack(pady=5)
message_entry = tk.Entry(alarm_window, width=40, font=("SimSun", 11))
message_entry.pack(pady=5)
def save_alarm():
alarm_date_str = date_entry.get().strip()
alarm_time_str = time_entry.get().strip()
alarm_message = message_entry.get().strip()
if not alarm_date_str:
alarm_date_str = datetime.now().strftime("%Y%m%d")
try:
if len(alarm_time_str) == 4:
alarm_time_str += "00"
alarm_datetime_str = f"{alarm_date_str} {alarm_time_str}"
alarm_time = datetime.strptime(alarm_datetime_str, "%Y%m%d %H%M%S")
if alarm_time < datetime.now():
messagebox.showwarning("警告", "提醒時間不能早于當(dāng)前時間!")
return
for i, (t_text, completed, a_time, c_time, _, _) in enumerate(self.tasks_by_date[date]):
if t_text == task_text and a_time == add_time:
if completed and c_time != "未完成":
completion_datetime = datetime.strptime(c_time, "%Y-%m-%d %H:%M:%S")
if alarm_time > completion_datetime:
completed = False
c_time = "未完成"
messagebox.showinfo("提示", f"任務(wù) '{task_text}' 的提醒時間晚于完成時間,已取消完成狀態(tài)")
self.tasks_by_date[date][i] = (task_text, completed, add_time, c_time,
alarm_time.strftime("%Y-%m-%d %H:%M:%S"), alarm_message)
break
if not completed:
self.set_alarm_timer(alarm_time, alarm_message, task_text, add_time, date)
self.save_tasks(silent=True)
self.refresh_display()
alarm_window.destroy()
except ValueError:
messagebox.showwarning("警告", "時間格式不正確,請使用 YYYYMMDD HHMMSS 或 YYYYMMDD HHMM 格式!")
tk.Button(alarm_window, text="保存", command=save_alarm, bg="#4CAF50", fg="white", bd=0).pack(pady=5)
def set_alarm_timer(self, alarm_time, alarm_message, task_text, add_time, date):
delay = (alarm_time - datetime.now()).total_seconds() * 1000
self.root.after(int(delay), lambda: self.show_alarm(alarm_message, task_text, add_time, date))
def show_alarm(self, alarm_message, task_text, add_time, date):
for task in self.tasks_by_date[date]:
if task[0] == task_text and task[2] == add_time and not task[1]:
messagebox.showinfo("提醒", f"任務(wù): {task_text}\n信息: {alarm_message}")
break
def check_alarms_on_startup(self):
current_time = datetime.now()
for date in self.tasks_by_date:
for i, (task_text, completed, add_time, completion_time, alarm_time_str, alarm_message) in enumerate(self.tasks_by_date[date]):
if alarm_time_str != "無":
try:
alarm_time = datetime.strptime(alarm_time_str, "%Y-%m-%d %H:%M:%S")
if completed and completion_time != "未完成":
completion_datetime = datetime.strptime(completion_time, "%Y-%m-%d %H:%M:%S")
if alarm_time > completion_datetime:
self.tasks_by_date[date][i] = (task_text, False, add_time, "未完成", alarm_time_str, alarm_message)
messagebox.showinfo("提示", f"任務(wù) '{task_text}' 的提醒時間晚于完成時間,已取消完成狀態(tài)")
if alarm_time <= current_time:
self.show_alarm(alarm_message, task_text, add_time, date)
else:
self.set_alarm_timer(alarm_time, alarm_message, task_text, add_time, date)
elif not completed:
if alarm_time <= current_time:
self.show_alarm(alarm_message, task_text, add_time, date)
else:
self.set_alarm_timer(alarm_time, alarm_message, task_text, add_time, date)
except ValueError:
continue
self.refresh_display()
self.save_tasks(silent=True)
def create_task_frame(self, task_text, completed, add_time, completion_time, date):
task_frame = tk.Frame(self.inner_frame, bg="#fafafa", bd=1, relief="solid", padx=8, pady=8)
var = tk.BooleanVar(value=completed)
checkbox = tk.Checkbutton(task_frame, variable=var, bg="#fafafa")
checkbox.pack(side=tk.LEFT, padx=(0, 5))
content_frame = tk.Frame(task_frame, bg="#fafafa")
content_frame.pack(side=tk.LEFT, fill=tk.X, expand=True)
label = tk.Label(content_frame, text=task_text, font=("SimSun", 11, "bold"),
bg="#fafafa", fg="#333333", wraplength=300, justify="left")
label.pack(anchor="w")
alarm_time = "無"
alarm_message = "無"
for t in self.tasks_by_date[date]:
if t[0] == task_text and t[2] == add_time and len(t) >= 6:
alarm_time = t[4]
alarm_message = t[5]
break
time_text = f"添加時間: {add_time}\n完成時間: {completion_time if completed else '未完成'}"
if alarm_time != "無" and not completed:
time_text += f"\n提醒時間: {alarm_time}\n提醒信息: {alarm_message}"
time_label = tk.Label(content_frame, text=time_text,
font=("SimSun", 9), bg="#fafafa",
fg="#2E7D32" if completed else "#757575",
height=4, justify="left")
time_label.pack(anchor="w", pady=2)
button_frame = tk.Frame(task_frame, bg="#fafafa")
button_frame.pack(side=tk.RIGHT, padx=5)
edit_button = tk.Button(button_frame, text="編輯", font=("SimSun", 11), bg="#2196F3", fg="white", bd=0,
command=lambda: self.edit_task(task_text, add_time, date, label))
edit_button.pack(side=tk.TOP, pady=2)
delete_button = tk.Button(button_frame, text="刪除", font=("SimSun", 11), bg="#F44336", fg="white", bd=0,
command=lambda: self.delete_task(task_text, add_time, date))
delete_button.pack(side=tk.TOP, pady=2)
alarm_button = tk.Button(button_frame, text="提醒", font=("SimSun", 11), bg="#FF9800", fg="white", bd=0,
command=lambda: self.set_alarm(task_text, add_time, date))
alarm_button.pack(side=tk.TOP, pady=2)
var.trace("w", lambda *args: self.update_completion_time(var, time_label, task_text, add_time, date))
return task_frame
def refresh_display(self):
for widget in self.inner_frame.winfo_children():
widget.destroy()
for date in sorted(self.tasks_by_date.keys(), reverse=True):
group_frame = tk.Frame(self.inner_frame, bg="#e0e0e0")
task_count = len(self.tasks_by_date[date])
toggle_button = tk.Button(group_frame, text=f"{'▼' if self.group_states.get(date, True) else '?'} {date} ({task_count} 項)",
font=("SimSun", 10, "bold"), bg="#e0e0e0", fg="#333333", bd=0,
command=lambda d=date, btn=group_frame: self.toggle_group(d, btn.winfo_children()[0]))
toggle_button.pack(side=tk.LEFT, padx=5, pady=2)
group_frame.pack(fill=tk.X, pady=5)
if self.group_states.get(date, True):
for i, (task_text, completed, add_time, completion_time, _, _) in enumerate(self.tasks_by_date[date]):
task_frame = self.create_task_frame(task_text, completed, add_time, completion_time, date)
task_frame.pack(fill=tk.X, pady=2 if i > 0 else (5, 2))
self.canvas.configure(scrollregion=self.canvas.bbox("all"))
def load_tasks(self):
if os.path.exists('tasks.csv'):
with open('tasks.csv', 'r', encoding='utf-8', newline='') as file:
reader = csv.reader(file)
for row in reader:
if row and len(row) >= 3:
task_text = row[0]
completed = row[1] == 'True'
add_time = row[2]
completion_time = row[3] if len(row) > 3 else "未完成"
alarm_time = row[4] if len(row) > 4 else "無"
alarm_message = row[5] if len(row) > 5 else "無"
date = add_time.split()[0]
if date not in self.tasks_by_date:
self.tasks_by_date[date] = []
self.group_states[date] = True
self.tasks_by_date[date].append((task_text, completed, add_time, completion_time,
alarm_time, alarm_message))
def save_tasks(self, silent=False):
with open('tasks.csv', 'w', encoding='utf-8', newline='') as file:
writer = csv.writer(file)
for date in sorted(self.tasks_by_date.keys(), reverse=True):
for task in self.tasks_by_date[date]:
writer.writerow(list(task) if len(task) == 6 else list(task) + ["無", "無"])
if not silent:
messagebox.showinfo("成功", "任務(wù)已保存!")
def run(self):
self.root.mainloop()
if __name__ == "__main__":
root = tk.Tk()
app = TodoApp(root)
app.run()
項目總結(jié)與收獲
通過本項目的開發(fā),我們掌握了:
- Tkinter高級組件的綜合運(yùn)用
- Python時間處理的最佳實(shí)踐
- 狀態(tài)管理與數(shù)據(jù)持久化方案
- 用戶體驗(yàn)優(yōu)化的具體方法
遇到的典型問題及解決方案:
問題:滾動區(qū)域內(nèi)容更新時閃爍
解決:使用Canvas+Frame組合代替直接滾動Frame
問題:提醒時間與完成狀態(tài)沖突
解決:添加時間邏輯校驗(yàn)
下一步學(xué)習(xí)建議:
- 嘗試添加語音提醒功能
- 學(xué)習(xí)PyQt5開發(fā)更復(fù)雜的界面
- 研究如何打包為exe可執(zhí)行文件
Q&A環(huán)節(jié):
Q:如何修改界面主題色?
A:只需修改代碼中的顏色常量,例如將"#f0f0f0"改為"#e6f7ff"可獲得淺藍(lán)色主題
以上就是Python+Tkinter實(shí)現(xiàn)高顏值桌面便簽工具的詳細(xì)內(nèi)容,更多關(guān)于Python桌面便簽工具的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python實(shí)現(xiàn)socket客戶端和服務(wù)端簡單示例
這篇文章主要介紹了python實(shí)現(xiàn)socket客戶端和服務(wù)端簡單示例,需要的朋友可以參考下2014-02-02
python turtle工具繪制四葉草的實(shí)例分享
在本篇文章里小編給各位整理的是關(guān)于python turtle工具繪制四葉草的實(shí)例分享,有興趣的朋友們可以跟著學(xué)習(xí)下。2020-02-02
python實(shí)現(xiàn)對文件進(jìn)行MD5校驗(yàn)
這篇文章主要為大家詳細(xì)介紹了如何使用python對文件進(jìn)行MD5校驗(yàn)并比對文件重復(fù),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01
Python控制流之循環(huán)控制詳解(break, continue, pass)
本文將詳細(xì)介紹這三種循環(huán)控制語句的使用方法和最佳實(shí)踐,并附上一個綜合詳細(xì)的例子,幫助您全面掌握Python循環(huán)控制的用法,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-04-04
python用opencv完成圖像分割并進(jìn)行目標(biāo)物的提取
這篇文章主要介紹了python用opencv完成圖像分割并進(jìn)行目標(biāo)物的提取,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05

