搜尋
首頁後端開發Python教學怎麼用Python寫個有趣的記仇本

怎麼用Python寫個有趣的記仇本

Apr 30, 2023 pm 11:40 PM
python

記仇本展示

如題所述,項目已經寫好了,是基於local_storage存儲在本地的項目

該項目運行時是基於brython, 你可能想問,為什麼不用原生python來寫網頁呢,這個有個誤解是,網頁是由html程式碼寫的,而原生python想要操作DOM非常難,所以brython正是為這個來操作的。

初始開啟頁面,因為沒有資料展示,所以只有一個增加按鈕。

怎麼用Python寫個有趣的記仇本

當我們點選【畫個圈圈記下來】按鈕後,會重新整理為新增頁面,例如:

怎麼用Python寫個有趣的記仇本

此時,我們只需要輸入訊息,例如記老婆的仇,緣由為買switch遊戲透露給丈母娘,還得被罵。

怎麼用Python寫個有趣的記仇本

此時點選記仇,就可以儲存到頁面上了。

怎麼用Python寫個有趣的記仇本

此時若點選已原諒,則可以刪除該記錄。

brython 之local_storage

你可能細心發現了,哎,關掉了瀏覽器,下次打開,怎麼還會有記錄在上面呢,這是因為用了 local_storage,那麼,什麼是local_storage呢?

哎,我們使用的是brython中的local_storage但是,它可不是python定義的哦,而是HTML 5提供的儲存資料的API之一,可以在瀏覽器中保持鍵值對資料塊。

現在來展示使用一下brython儲存和刪除的操作。

導入庫:

from browser.local_storage import storage

儲存數據,例如鍵值資訊juejinName儲存為pdudo

storage[juejinName] = "pdudo"

查詢的話,直接使用storage[變數]就好,若為空,則回傳None

v = storage[juejinName]

循環所有的key,需要引入 window庫,再使用for...in來完成

from browser import window
for key in window.localStorage:
    print(key)

也可以直接使用for...in來遍歷storage

而刪除資料呢?只需要像刪除字典一下

del storage[juejinName]

storage是不是操作起來跟字典很相似呢?減少了開發者的學習成本。

製作項目

有了上述前置條件後,我們再看該項目,便可以總結為針對localStorage的增刪查,首先當頁面加載出來的時候,我們需要先遍歷一下localstorage數據,從而映射為一個table#,例如:

  for key in window.localStorage:
    tr = html.TR()
    datas = json.loads(storage[key])

    delBtn = html.BUTTON("已原谅")
    delBtn.dataset["id"] = datas["id"]
    delBtn.className = "confirm-btn"
    delBtn.bind("click",delGrudges)

    td = html.TD(delBtn+" "+time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(int(datas["id"]))))
    tr <= td

    for tdVal in datas["whos"],datas["Text"]:
      td = html.TD(tdVal)
      tr <= td
        
    tb <= tr 

    userWindows <= tb

上述程式碼是遍歷localStorage,而後在定義刪除按鈕,等將其他值組合完畢後,全部載入進table#中,而後再頁面上顯示。

而加入資料呢?

def saveGrudges(ev):
  getWhoVal = document["whos"].value
  getTextVal = document["textArea"].value

  if getWhoVal == "" or getTextVal == "":
    return
  
  document["saveBtn"].unbind("click")


  ids = int(time.time())
  datas = {
    "id": ids,
    "whos": getWhoVal,
    "Text": getTextVal
  }

  storage[str(ids)] = json.dumps(datas)

上述程式碼,顯示取得inputtextarea方塊中的值,再判斷是否使用者沒有輸入,我們將資料組裝為字典,而後轉換為字串,再存入localstage中。

還有其他操作,這個可以直接看程式碼說明,brython很簡單的。

以上是怎麼用Python寫個有趣的記仇本的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
您如何切成python陣列?您如何切成python陣列?May 01, 2025 am 12:18 AM

Python列表切片的基本語法是list[start:stop:step]。 1.start是包含的第一個元素索引,2.stop是排除的第一個元素索引,3.step決定元素之間的步長。切片不僅用於提取數據,還可以修改和反轉列表。

在什麼情況下,列表的表現比數組表現更好?在什麼情況下,列表的表現比數組表現更好?May 01, 2025 am 12:06 AM

ListSoutPerformarRaysin:1)DynamicsizicsizingandFrequentInsertions/刪除,2)儲存的二聚體和3)MemoryFeliceFiceForceforseforsparsedata,butmayhaveslightperformancecostsinclentoperations。

如何將Python數組轉換為Python列表?如何將Python數組轉換為Python列表?May 01, 2025 am 12:05 AM

toConvertapythonarraytoalist,usEthelist()constructororageneratorexpression.1)intimpthearraymoduleandcreateanArray.2)USELIST(ARR)或[XFORXINARR] to ConconverTittoalist,請考慮performorefformanceandmemoryfformanceandmemoryfformienceforlargedAtasetset。

當Python中存在列表時,使用數組的目的是什麼?當Python中存在列表時,使用數組的目的是什麼?May 01, 2025 am 12:04 AM

choosearraysoverlistsinpythonforbetterperformanceandmemoryfliceSpecificScenarios.1)largenumericaldatasets:arraysreducememoryusage.2)績效 - 臨界雜貨:arraysoffersoffersOffersOffersOffersPoostSfoostSforsssfortasssfortaskslikeappensearch orearch.3)testessenforcety:arraysenforce:arraysenforc

說明如何通過列表和數組的元素迭代。說明如何通過列表和數組的元素迭代。May 01, 2025 am 12:01 AM

在Python中,可以使用for循環、enumerate和列表推導式遍歷列表;在Java中,可以使用傳統for循環和增強for循環遍歷數組。 1.Python列表遍歷方法包括:for循環、enumerate和列表推導式。 2.Java數組遍歷方法包括:傳統for循環和增強for循環。

什麼是Python Switch語句?什麼是Python Switch語句?Apr 30, 2025 pm 02:08 PM

本文討論了版本3.10中介紹的Python的新“匹配”語句,該語句與其他語言相同。它增強了代碼的可讀性,並為傳統的if-elif-el提供了性能優勢

Python中有什麼例外組?Python中有什麼例外組?Apr 30, 2025 pm 02:07 PM

Python 3.11中的異常組允許同時處理多個異常,從而改善了並發方案和復雜操作中的錯誤管理。

Python中的功能註釋是什麼?Python中的功能註釋是什麼?Apr 30, 2025 pm 02:06 PM

Python中的功能註釋將元數據添加到函數中,以進行類型檢查,文檔和IDE支持。它們增強了代碼的可讀性,維護,並且在API開發,數據科學和圖書館創建中至關重要。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。